1
0
mirror of https://github.com/node-red/node-red-nodes.git synced 2023-10-10 13:36:58 +02:00

better inplace upgrade of pre v1 (#908)

fixes #907
This commit is contained in:
Stephen McLaughlin 2022-05-07 16:40:57 +01:00 committed by GitHub
parent c77f13a90f
commit 041342d511
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 42 additions and 27 deletions

View File

@ -1,6 +1,6 @@
{ {
"name" : "node-red-node-snmp", "name" : "node-red-node-snmp",
"version" : "1.0.0", "version" : "1.0.1",
"description" : "A Node-RED node that gets and sets SNMP oid values. Supports v1, v2c and v3", "description" : "A Node-RED node that gets and sets SNMP oid values. Supports v1, v2c and v3",
"dependencies" : { "dependencies" : {
"net-snmp" : "^3.6.3" "net-snmp" : "^3.6.3"

View File

@ -12,14 +12,20 @@
<script type="text/javascript" id="node-red-node-snmp-common-script"> <script type="text/javascript" id="node-red-node-snmp-common-script">
const node_snmp_common = { const node_snmp_common = {
oneditprepare: function (node) { oneditprepare: function (node) {
const compat = { "v1": "1", "v2": "2c", "v2c": "2c", "v3": "3" };
if(compat[node.version]) {
node.version = compat[node.version];
} else if(["1","2c","3"].indexOf(node.version) < 0) {
node.version = "1";
}
$("#node-input-version").on("change", function(evt) { $("#node-input-version").on("change", function(evt) {
const isV3 = $("#node-input-version").val() === "v3"; const isV3 = $("#node-input-version").val() === "3";
$(".form-row-snmpv1v2").toggleClass("hidden", isV3); $(".form-row-snmpv1v2").toggleClass("hidden", isV3);
$(".form-row-snmpv3").toggleClass("hidden", !isV3); $(".form-row-snmpv3").toggleClass("hidden", !isV3);
$("#node-input-auth").trigger("change"); $("#node-input-auth").trigger("change");
}); });
$("#node-input-auth").on("change", function(evt) { $("#node-input-auth").on("change", function(evt) {
const isV3 = $("#node-input-version").val() === "v3"; const isV3 = $("#node-input-version").val() === "3";
const auth = $("#node-input-auth").val(); const auth = $("#node-input-auth").val();
if(isV3) { if(isV3) {
switch (auth) { switch (auth) {
@ -38,6 +44,10 @@
} }
} }
}); });
$("#node-input-version").val(node.version);
if(!$("#node-input-auth").val()) {
$("#node-input-auth").val("noAuthNoPriv");
}
$("#node-input-version").trigger("change"); $("#node-input-version").trigger("change");
} }
} }
@ -50,9 +60,9 @@
<div class="form-row"> <div class="form-row">
<label for="node-input-version"><i class="fa fa-bookmark"></i> Version</label> <label for="node-input-version"><i class="fa fa-bookmark"></i> Version</label>
<select type="text" id="node-input-version" style="width:150px;"> <select type="text" id="node-input-version" style="width:150px;">
<option value="v1">v1</option> <option value="1">v1</option>
<option value="v2c">v2c</option> <option value="2c">v2c</option>
<option value="v3">v3</option> <option value="3">v3</option>
</select> </select>
<span style="margin-left:50px;">Timeout</span> <span style="margin-left:50px;">Timeout</span>
<input type="text" id="node-input-timeout" placeholder="secs" style="width:50px; direction:rtl; vertical-align:baseline;">&nbsp;S <input type="text" id="node-input-timeout" placeholder="secs" style="width:50px; direction:rtl; vertical-align:baseline;">&nbsp;S
@ -126,7 +136,7 @@
color: "YellowGreen", color: "YellowGreen",
defaults: { defaults: {
host: { value: "127.0.0.1" }, host: { value: "127.0.0.1" },
version: { value: "v1", required: true }, version: { value: "1", required: true },
timeout: { value: 5 }, timeout: { value: 5 },
community: { value: "public" }, community: { value: "public" },
auth: { value: "noAuthNoPriv", required: true }, auth: { value: "noAuthNoPriv", required: true },
@ -163,10 +173,10 @@
<div class="form-row"> <div class="form-row">
<label for="node-input-version"><i class="fa fa-bookmark"></i> Version</label> <label for="node-input-version"><i class="fa fa-bookmark"></i> Version</label>
<select type="text" id="node-input-version" style="width:150px;"> <select type="text" id="node-input-version" style="width:150px;">
<option value="v1">v1</option> <option value="1">v1</option>
<option value="v2c">v2c</option> <option value="2c">v2c</option>
<!-- Following Data is used for V3 Only --> <!-- Following Data is used for V3 Only -->
<option value="v3">v3</option> <option value="3">v3</option>
<!-- End of unique data for V3 --> <!-- End of unique data for V3 -->
</select> </select>
<span style="margin-left:50px;">Timeout</span> <span style="margin-left:50px;">Timeout</span>
@ -251,7 +261,7 @@
color: "YellowGreen", color: "YellowGreen",
defaults: { defaults: {
host: { value: "127.0.0.1" }, host: { value: "127.0.0.1" },
version: { value: "v1", required: true }, version: { value: "1", required: true },
timeout: { value: 5 }, timeout: { value: 5 },
community: { value: "public" }, community: { value: "public" },
auth: { value: "noAuthNoPriv", required: true }, auth: { value: "noAuthNoPriv", required: true },
@ -295,10 +305,10 @@
<div class="form-row"> <div class="form-row">
<label for="node-input-version"><i class="fa fa-bookmark"></i> Version</label> <label for="node-input-version"><i class="fa fa-bookmark"></i> Version</label>
<select type="text" id="node-input-version" style="width:150px;"> <select type="text" id="node-input-version" style="width:150px;">
<option value="v1">v1</option> <option value="1">v1</option>
<option value="v2c">v2c</option> <option value="2c">v2c</option>
<!-- Following Data is used for V3 Only --> <!-- Following Data is used for V3 Only -->
<option value="v3">v3</option> <option value="3">v3</option>
<!-- End of unique data for V3 --> <!-- End of unique data for V3 -->
</select> </select>
<span style="margin-left:50px;">Timeout</span> <span style="margin-left:50px;">Timeout</span>
@ -373,7 +383,7 @@
color: "YellowGreen", color: "YellowGreen",
defaults: { defaults: {
host: { value: "127.0.0.1" }, host: { value: "127.0.0.1" },
version: { value: "v1", required: true }, version: { value: "1", required: true },
timeout: { value: 5 }, timeout: { value: 5 },
community: { value: "public" }, community: { value: "public" },
auth: { value: "noAuthNoPriv", required: true }, auth: { value: "noAuthNoPriv", required: true },
@ -410,10 +420,10 @@
<div class="form-row"> <div class="form-row">
<label for="node-input-version"><i class="fa fa-bookmark"></i> Version</label> <label for="node-input-version"><i class="fa fa-bookmark"></i> Version</label>
<select type="text" id="node-input-version" style="width:150px;"> <select type="text" id="node-input-version" style="width:150px;">
<option value="v1">v1</option> <option value="1">v1</option>
<option value="v2c">v2c</option> <option value="2c">v2c</option>
<!-- Following Data is used for V3 Only --> <!-- Following Data is used for V3 Only -->
<option value="v3">v3</option> <option value="3">v3</option>
<!-- End of unique data for V3 --> <!-- End of unique data for V3 -->
</select> </select>
<span style="margin-left:50px;">Timeout</span> <span style="margin-left:50px;">Timeout</span>
@ -488,7 +498,7 @@
color: "YellowGreen", color: "YellowGreen",
defaults: { defaults: {
host: { value: "127.0.0.1" }, host: { value: "127.0.0.1" },
version: { value: "v1", required: true }, version: { value: "1", required: true },
timeout: { value: 5 }, timeout: { value: 5 },
community: { value: "public" }, community: { value: "public" },
auth: { value: "noAuthNoPriv", required: true }, auth: { value: "noAuthNoPriv", required: true },
@ -526,10 +536,10 @@
<div class="form-row"> <div class="form-row">
<label for="node-input-version"><i class="fa fa-bookmark"></i> Version</label> <label for="node-input-version"><i class="fa fa-bookmark"></i> Version</label>
<select type="text" id="node-input-version" style="width:150px;"> <select type="text" id="node-input-version" style="width:150px;">
<option value="v1">v1</option> <option value="1">v1</option>
<option value="v2c">v2c</option> <option value="2c">v2c</option>
<!-- Following Data is used for V3 Only --> <!-- Following Data is used for V3 Only -->
<option value="v3">v3</option> <option value="3">v3</option>
<!-- End of unique data for V3 --> <!-- End of unique data for V3 -->
</select> </select>
<span style="margin-left:50px;">Timeout</span> <span style="margin-left:50px;">Timeout</span>
@ -607,7 +617,7 @@
color: "YellowGreen", color: "YellowGreen",
defaults: { defaults: {
host: { value: "127.0.0.1" }, host: { value: "127.0.0.1" },
version: { value: "v1", required: true }, version: { value: "1", required: true },
timeout: { value: 5 }, timeout: { value: 5 },
community: { value: "public" }, community: { value: "public" },
auth: { value: "noAuthNoPriv", required: true }, auth: { value: "noAuthNoPriv", required: true },

View File

@ -61,15 +61,20 @@ module.exports = function (RED) {
const sessionid = generateUUID(); const sessionid = generateUUID();
const user = {} const user = {}
const options = {}; const options = {};
const compat = { "v1": "1", "v2": "2c", "v2c": "2c", "v3": "3" };
if(compat[node.version]) {
node.version = compat[node.version];
} else if(["1","2c","3"].indexOf(node.version) < 0) {
node.version = "1";
}
options.version = node.version; options.version = node.version;
if (node.version === "v1") { if (node.version === "1") {
options.version = SNMP.Version1; options.version = SNMP.Version1;
user.community = node.community || msg.community; user.community = node.community || msg.community;
} else if (node.version === "v2c") { } else if (node.version === "2c") {
options.version = SNMP.Version2c; options.version = SNMP.Version2c;
user.community = node.community || msg.community; user.community = node.community || msg.community;
} else if (node.version === "v3") { } else if (node.version === "3") {
user.name = node.username || msg.username || ""; user.name = node.username || msg.username || "";
user.level = SNMP.SecurityLevel.noAuthNoPriv; user.level = SNMP.SecurityLevel.noAuthNoPriv;
user.authProtocol = SNMP.AuthProtocols.none; user.authProtocol = SNMP.AuthProtocols.none;