Skip to content

Commit

Permalink
Better error catching in ping node for spawn errors...
Browse files Browse the repository at this point in the history
  • Loading branch information
Dave Conway-Jones committed Dec 5, 2018
1 parent 739e8cd commit 89d7853
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 3 deletions.
14 changes: 14 additions & 0 deletions io/ping/88-ping.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ module.exports = function(RED) {
else { node.error("Sorry - your platform - "+plat+" - is not recognised."); }
var res = false;
var line = "";
var fail = false;
//var regex = /from.*time.(.*)ms/;
var regex = /=.*[<|=]([0-9]*).*TTL|ttl..*=([0-9\.]*)/;
ex.stdout.on('data', function (data) {
Expand All @@ -26,7 +27,20 @@ module.exports = function(RED) {
//ex.stderr.on('data', function (data) {
//console.log('[ping] stderr: ' + data);
//});
ex.on('error', function (err) {
fail = true;
if (err.code === "ENOENT") {
node.error(err.code + " ping command not found");
}
else if (err.code === "EACCES") {
node.error(err.code + " can't run ping command");
}
else {
node.error(err.code);
}
});
ex.on('close', function (code) {
if (fail) { fail = false; return; }
var m = regex.exec(line)||"";
if (m !== '') {
if (m[1]) { res = Number(m[1]); }
Expand Down
6 changes: 4 additions & 2 deletions io/ping/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,11 @@ Run the following command in your Node-RED user directory - typically `~/.node-r

npm install node-red-node-ping

**Gotcha**
**Gotchas**

On some versions on Raspbian (Raspberry Pi) `ping` seems to be a root only command.
1 This won't run on Ubunti Snap as the strict container does not allow spawning of external commands (like ping).

2 On some versions on Raspbian (Raspberry Pi) `ping` seems to be a root only command.
The fix is to allow it as follows

sudo setcap cap_net_raw=ep /bin/ping
Expand Down
2 changes: 1 addition & 1 deletion io/ping/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name" : "node-red-node-ping",
"version" : "0.0.15",
"version" : "0.0.16",
"description" : "A Node-RED node to ping a remote server, for use as a keep-alive check.",
"dependencies" : {
},
Expand Down

0 comments on commit 89d7853

Please sign in to comment.