From 1e2521c37a215d6c7667144d3434e7b83caaee06 Mon Sep 17 00:00:00 2001 From: Nick O'Leary Date: Wed, 27 Apr 2016 12:31:54 +0100 Subject: [PATCH] Add TLS node and update MQTT/HTTP nodes to use it --- nodes/core/io/05-tls.html | 73 ++++++++++++++++++++++++++ nodes/core/io/05-tls.js | 69 ++++++++++++++++++++++++ nodes/core/io/10-mqtt.html | 32 ++++++----- nodes/core/io/10-mqtt.js | 17 +++++- nodes/core/io/21-httprequest.html | 70 +++++++++++++++++------- nodes/core/io/21-httprequest.js | 17 ++++-- nodes/core/locales/en-US/messages.json | 22 +++++++- 7 files changed, 257 insertions(+), 43 deletions(-) create mode 100644 nodes/core/io/05-tls.html create mode 100644 nodes/core/io/05-tls.js diff --git a/nodes/core/io/05-tls.html b/nodes/core/io/05-tls.html new file mode 100644 index 000000000..05015f3ec --- /dev/null +++ b/nodes/core/io/05-tls.html @@ -0,0 +1,73 @@ + + + + + + + diff --git a/nodes/core/io/05-tls.js b/nodes/core/io/05-tls.js new file mode 100644 index 000000000..9914438dc --- /dev/null +++ b/nodes/core/io/05-tls.js @@ -0,0 +1,69 @@ +/** + * Copyright 2016 IBM Corp. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + **/ + +var fs = require('fs'); +module.exports = function(RED) { + "use strict"; + + function TLSConfig(n) { + RED.nodes.createNode(this,n); + this.valid = true; + var certPath = n.cert.trim(); + var keyPath = n.key.trim(); + var caPath = n.ca.trim(); + + if ( (certPath.length > 0) !== (keyPath.length > 0)) { + this.valid = false; + this.error(RED._("tls.error.missing-file")); + return; + } + this.verifyservercert = n.verifyservercert; + + try { + if (certPath) { + this.cert = fs.readFileSync(certPath); + } + if (keyPath) { + this.key = fs.readFileSync(keyPath); + } + if (caPath) { + this.ca = fs.readFileSync(caPath); + } + } catch(err) { + this.valid = false; + this.error(err.toString()); + return; + } + } + RED.nodes.registerType("tls-config",TLSConfig); + + TLSConfig.prototype.addTLSOptions = function(opts) { + if (this.valid) { + if (this.key) { + opts.key = this.key; + } + if (this.cert) { + opts.cert = this.cert; + } + if (this.ca) { + opts.ca = this.ca; + } + opts.rejectUnauthorized = this.verifyservercert; + } + return opts; + } + +} diff --git a/nodes/core/io/10-mqtt.html b/nodes/core/io/10-mqtt.html index 65674f6bc..c80818c26 100644 --- a/nodes/core/io/10-mqtt.html +++ b/nodes/core/io/10-mqtt.html @@ -150,11 +150,17 @@ +
+ + +
+ +
+
-
@@ -175,14 +181,6 @@
-
- - -
-
- - -