From 918c0edeb5cdf31af219ffe2ae982c48bb188c23 Mon Sep 17 00:00:00 2001 From: Sam Roberts Date: Wed, 1 May 2019 12:51:44 -0700 Subject: [PATCH] tls: disallow conflicting TLS protocol options Do not allow the minimum protocol level to be set higher than the max protocol level. See: https://github.com/nodejs/node/pull/26951, 109c097797b --- src/node_options.cc | 5 +++++ test/parallel/test-tls-cli-min-max-conflict.js | 14 ++++++++++++++ 2 files changed, 19 insertions(+) create mode 100644 test/parallel/test-tls-cli-min-max-conflict.js diff --git a/src/node_options.cc b/src/node_options.cc index 552997e58cf5a2..b2f14d2056eb37 100644 --- a/src/node_options.cc +++ b/src/node_options.cc @@ -148,6 +148,11 @@ void EnvironmentOptions::CheckOptions(std::vector* errors) { errors->push_back("invalid value for --unhandled-rejections"); } + if (tls_min_v1_3 && tls_max_v1_2) { + errors->push_back("either --tls-min-v1.3 or --tls-max-v1.2 can be " + "used, not both"); + } + #if HAVE_INSPECTOR if (!cpu_prof) { if (!cpu_prof_name.empty()) { diff --git a/test/parallel/test-tls-cli-min-max-conflict.js b/test/parallel/test-tls-cli-min-max-conflict.js new file mode 100644 index 00000000000000..68aae4c635bcec --- /dev/null +++ b/test/parallel/test-tls-cli-min-max-conflict.js @@ -0,0 +1,14 @@ +'use strict'; +const common = require('../common'); +if (!common.hasCrypto) common.skip('missing crypto'); + +// Check that conflicting TLS protocol versions are not allowed + +const assert = require('assert'); +const child_process = require('child_process'); + +const args = ['--tls-min-v1.3', '--tls-max-v1.2', '-p', 'process.version']; +child_process.execFile(process.argv[0], args, (err) => { + assert(err); + assert(/not both/.test(err.message)); +});