cambios camacho v1
[VSoRC/.git] / src / routes / index.js
index 51f81466c032defce62f7f0eb50113ad219a620f..0084754861ae7c4e74a69dc46c054abe8280a06d 100644 (file)
@@ -24,7 +24,8 @@ router.get("/stats", (req, res) => {
 router.get("/topology", (req, res) => {
   res.render("topology")
 });
-
+let isVsorcUP = false;
+let isControllerUP = false;
 router.get("/topologyMaker", (req, res) => {
   res.render("topologyMaker")
 });
@@ -61,6 +62,15 @@ router.get('/ifstat', (req, res) => {
   });
 });
 
+router.get('/showtemp', (req, res) => {
+  var sys = require('sys')
+  var exec = require('child_process').exec;
+  var child;
+  child = exec("cd /home/pi/scripts && ./gettemp.sh", function(error, stdout, stderr) {
+    console.log("show temp");
+    res.send(stdout);
+  });
+});
 router.get('/gettopo', (req, res) => {
   var sys = require('sys')
   var exec = require('child_process').exec;
@@ -76,7 +86,17 @@ router.get('/net', (req, res) => {
   var exec = require('child_process').exec;
   var child;
   child = exec("cd /home/pi/scripts && echo net > fifo", function(error, stdout, stderr) {
-    console.log("pingall");
+    console.log("net");
+    res.send(stdout);
+  });
+});
+
+router.get('/rpiping', (req, res) => {
+  var sys = require('sys')
+  var exec = require('child_process').exec;
+  var child;
+  child = exec("cd /home/pi/scripts && ./rpiping.sh", function(error, stdout, stderr) {
+    console.log("rpiping");
     res.send(stdout);
   });
 });
@@ -86,17 +106,17 @@ router.get('/nodes', (req, res) => {
   var exec = require('child_process').exec;
   var child;
   child = exec("cd /home/pi/scripts && echo nodes > fifo", function(error, stdout, stderr) {
-    console.log("pingall");
+    console.log("nodes");
     res.send(stdout);
   });
 });
 
-router.get('/status', (req, res) => {
+router.get('/statusnodes', (req, res) => {
   var sys = require('sys')
   var exec = require('child_process').exec;
   var child;
   child = exec("cd /home/pi/scripts && echo status > fifo", function(error, stdout, stderr) {
-    console.log("pingall");
+    console.log("status");
     res.send(stdout);
   });
 });
@@ -106,7 +126,7 @@ router.get('/intfs', (req, res) => {
   var exec = require('child_process').exec;
   var child;
   child = exec("cd /home/pi/scripts && echo intfs > fifo", function(error, stdout, stderr) {
-    console.log("pingall");
+    console.log("interfaces");
     res.send(stdout);
   });
 });
@@ -141,21 +161,32 @@ router.get('/placement', (req, res) => {
 });
 
 router.get('/getvsorcdata', (req, res) => {
+
   var sys = require('sys')
   var exec = require('child_process').exec;
   var child;
-  child = exec("cd /home/pi/scripts && cat aichivo 2>&1", function(error, stdout, stderr) {
+  var child2;
+  child2 = exec("ps aux | grep GRE| grep sudo | grep -v tail| awk {'print $2'}", function(error, stdout, stderr) {
+    console.log("view status vsorc");
+    if (stdout === ""){
+      isVsorcUP = false;
+    }else {
+      isVsorcUP = true;
+    }
+  });
+  child = exec("cd /home/pi/scripts && cat aichivo 2>/dev/null", function(error, stdout, stderr) {
     console.log("getting vsorc data");
-    res.send(stdout);
+    res.send(stdout+"^"+isVsorcUP);
   });
+
 });
 router.get('/getcontrollerdata', (req, res) => {
   var sys = require('sys')
   var exec = require('child_process').exec;
   var child;
-  child = exec("cd /home/pi/scripts && cat controllerout 2>&1", function(error, stdout, stderr) {
+  child = exec("cd /home/pi/scripts && cat controllerout 2>/dev/null", function(error, stdout, stderr) {
     console.log("getting controller data");
-    res.send(stdout);
+    res.send(stdout+"^"+isControllerUP);
   });
 });
 router.get('/listswitch', (req, res) => {
@@ -196,6 +227,7 @@ router.get('/status', (req, res) => {
 
 
 router.get('/startcontroller', (req, res) => {
+  isControllerUP = true;
   var sys = require('sys')
   var exec = require('child_process').exec;
   var child;
@@ -208,6 +240,7 @@ router.get('/startcontroller', (req, res) => {
 });
 
 router.get('/stopcontroller', (req, res) => {
+  isControllerUP = false;
   var sys = require('sys')
   var exec = require('child_process').exec;
   var child;
@@ -216,14 +249,34 @@ router.get('/stopcontroller', (req, res) => {
     res.send(stdout);
   });
 });
-
+router.get('/sendcommand', (req, res) => {
+  var sys = require('sys')
+  var exec = require('child_process').exec;
+  var child;
+  request = JSON.parse(req.query.cmd); //recibiendo el comando
+  child = exec("cd /home/pi/scripts && echo \""+request+"\" > fifo", function(error, stdout, stderr) {
+    console.log("command received \n" + request+"\n");
+    res.send(stdout);
+  });
+});
+router.get('/cancel', (req, res) => {
+  var sys = require('sys')
+  var exec = require('child_process').exec;
+  var child;
+  child = exec("sudo kill -2 $(ps aux | grep GRE| grep sudo|awk {'print $2'})", function(error, stdout, stderr) {
+    console.log("cancelled");
+    res.send(stdout);
+  });
+});
 router.get('/startvsorc', (req, res) => {
+
   var sys = require('sys')
   var exec = require('child_process').exec;
   var child0;//needs a mkfifo named fifo to exist
   var child1;
   var child2;
   var child3;
+  var child4;
   var answer;
   request = JSON.parse(req.query.topology)
   console.log("Topology is : \n"+ request);
@@ -232,7 +285,7 @@ router.get('/startvsorc', (req, res) => {
     console.log(stdout + stderr);
     answer+=stdout;
   });
-  child1 = exec("cd /home/pi/scripts && mkfifo fifo && touch aichivo", function(error, stdout, stderr) {
+  child1 = exec("cd /home/pi/scripts && mkfifo fifo && rm aichivo && touch aichivo", function(error, stdout, stderr) {
     console.log(stdout + stderr);
     answer+=stdout;
   });
@@ -240,6 +293,8 @@ router.get('/startvsorc', (req, res) => {
     console.log(stdout + stderr);
     answer+=stdout;
   });
+
+
   //child3 uses tail so it can read from fifo even after a EOF
   child3 = exec("cd /home/pi/scripts && tail -n +1 -f fifo | sudo ./clusterGRE.py > aichivo 2>&1 &", function(error, stdout, stderr) {
     console.log(stdout + stderr);
@@ -249,6 +304,7 @@ router.get('/startvsorc', (req, res) => {
 });
 
 router.get('/stopvsorc', (req,res) =>{
+
   var sys = require('sys')
   var exec = require('child_process').exec;
   var child1;
@@ -256,25 +312,25 @@ router.get('/stopvsorc', (req,res) =>{
   var child3;
   var payload
   console.log("erasing...");
-  child1 = exec("cd /home/pi/scripts && exec 3>&- && rm fifo && rm aichivo", function(error, stdout, stderr) {
+  child1 = exec("cd /home/pi/scripts && exec 3>&- ", function(error, stdout, stderr) {
     console.log(stdout);
 
     payload+="rm done\n\n"+stdout;
   });//esto cierra el fifo, lo cual cierra el programa
 
-  //sudo kill $(ps aux | grep GRE| grep sudo|awk {'print $2'}) && cd /home/pi && ./multissh.sh sudo -E mn -c; sudo -E mn -c
-  console.log("killing all...");
-  child2 = exec("sudo kill $(ps aux | grep GRE| grep sudo|awk {'print $2'})", function(error, stdout, stderr) {
+  //antes, en ves de echo exit > fifo, estaba sudo kill $(ps aux | grep GRE| grep sudo|awk {'print $2'})
+  console.log("Exiting...");
+  child2 = exec("cd /home/pi/scripts && echo exit > fifo && rm fifo", function(error, stdout, stderr) {
     console.log(stdout);
     payload+="killed\n\n"+stdout;
   });
-  console.log("Multisshing and cleaning...");
-  child3 = exec("cd /home/pi/scripts && ./multissh.sh sudo -E mn -c; sudo -E mn -c", function(error, stdout, stderr) {
-    console.log(stdout);
-    console.log("multisshed");
-    payload+="Multisshed\n\n"+stdout;
-
-  });
+  // console.log("Multisshing and cleaning...");
+  // child3 = exec("cd /home/pi/scripts && ./multissh.sh sudo -E mn -c; sudo -E mn -c", function(error, stdout, stderr) {
+  //   console.log(stdout);
+  //   console.log("multisshed");
+  //   payload+="Multisshed\n\n"+stdout;
+  //
+  // });
   res.send(payload);
 });
 module.exports = router;