X-Git-Url: https://git.josue.xyz/?a=blobdiff_plain;f=src%2Froutes%2Findex.js;h=0084754861ae7c4e74a69dc46c054abe8280a06d;hb=ea20f018c05bcc4e56b2dfa3eee30af0d6ffabf3;hp=371ba2c4837f08b4b9e31bd1288ce3e301477168;hpb=bc809c6977606f57fd4e4fbae288524a7bae5c33;p=VSoRC%2F.git diff --git a/src/routes/index.js b/src/routes/index.js index 371ba2c..0084754 100644 --- a/src/routes/index.js +++ b/src/routes/index.js @@ -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") }); @@ -33,7 +34,7 @@ router.get('/free', (req, res) => { var sys = require('sys') var exec = require('child_process').exec; var child; - child = exec("free -b | grep Mem | awk '{print $7}'", function(error, stdout, stderr) { + child = exec("free -b | grep Mem | awk '{print $3}'", function(error, stdout, stderr) { console.log("free"); res.send(stdout); }); @@ -44,7 +45,7 @@ router.get('/mpstat', (req, res) => { var sys = require('sys') var exec = require('child_process').exec; var child; - child = exec("mpstat 1 1| grep all | awk '{print $13}'", function(error, stdout, stderr) { + child = exec("mpstat 1 1| grep all | grep Average | awk '{print $12}'", function(error, stdout, stderr) { console.log("mpstat"); res.send(stdout); }); @@ -55,12 +56,21 @@ router.get('/ifstat', (req, res) => { var sys = require('sys') var exec = require('child_process').exec; var child; - child = exec("ifstat -n -b -i wlp2s0 0.3 1 | grep [0-9]$", function(error, stdout, stderr) { + child = exec("ifstat -n -b -i eth0 0.3 1 | grep [0-9]$", function(error, stdout, stderr) { console.log("ifstat"); res.send(stdout); }); }); +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; @@ -71,11 +81,71 @@ router.get('/gettopo', (req, res) => { }); }); +router.get('/net', (req, res) => { + var sys = require('sys') + var exec = require('child_process').exec; + var child; + child = exec("cd /home/pi/scripts && echo net > fifo", function(error, stdout, stderr) { + 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); + }); +}); + +router.get('/nodes', (req, res) => { + var sys = require('sys') + var exec = require('child_process').exec; + var child; + child = exec("cd /home/pi/scripts && echo nodes > fifo", function(error, stdout, stderr) { + console.log("nodes"); + res.send(stdout); + }); +}); + +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("status"); + res.send(stdout); + }); +}); + +router.get('/intfs', (req, res) => { + var sys = require('sys') + var exec = require('child_process').exec; + var child; + child = exec("cd /home/pi/scripts && echo intfs > fifo", function(error, stdout, stderr) { + console.log("interfaces"); + res.send(stdout); + }); +}); + +router.get('/iperf', (req, res) => { + var sys = require('sys') + var exec = require('child_process').exec; + var child; + child = exec("cd /home/pi/scripts && echo iperf > fifo", function(error, stdout, stderr) { + console.log("pingall"); + res.send(stdout); + }); +}); + router.get('/pingall', (req, res) => { var sys = require('sys') var exec = require('child_process').exec; var child; - child = exec("cd /home/pi && echo pingall > fifo", function(error, stdout, stderr) { + child = exec("cd /home/pi/scripts && echo pingall > fifo", function(error, stdout, stderr) { console.log("pingall"); res.send(stdout); }); @@ -84,28 +154,39 @@ router.get('/placement', (req, res) => { var sys = require('sys') var exec = require('child_process').exec; var child; - child = exec("cd /home/pi && echo placement > fifo", function(error, stdout, stderr) { + child = exec("cd /home/pi/scripts && echo placement > fifo", function(error, stdout, stderr) { console.log("placement"); res.send(stdout); }); }); router.get('/getvsorcdata', (req, res) => { + var sys = require('sys') var exec = require('child_process').exec; var child; - child = exec("cd /home/pi && 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 && 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) => { @@ -146,52 +227,76 @@ router.get('/status', (req, res) => { router.get('/startcontroller', (req, res) => { + isControllerUP = true; var sys = require('sys') var exec = require('child_process').exec; var child; //cd /home/pi && setsid $(cat /home/pi/ejecutarcontroller.sh | grep sudo) >/dev/null 2>&1 < /dev/null & //cd /home/pi && ./ejecutarcontroller.sh > /dev/null 2>&1 < /dev/null & //comando anterior - child = exec("cd /home/pi && rm controllerout && touch controllerout && ./ejecutarcontroller.sh > controllerout 2>&1 &", function(error, stdout, stderr) { + child = exec("cd /home/pi/scripts && touch controllerout && ./ejecutarcontroller.sh > controllerout 2>&1 &", function(error, stdout, stderr) { console.log("controller started"); res.send(stdout); }); }); router.get('/stopcontroller', (req, res) => { + isControllerUP = false; var sys = require('sys') var exec = require('child_process').exec; var child; - child = exec("cd /home/pi && rm controllerout && sudo kill $(ps aux | grep python | grep ryu | awk {'print $2'})", function(error, stdout, stderr) { + child = exec("cd /home/pi/scripts && rm controllerout && sudo kill $(ps aux | grep python | grep ryu | awk {'print $2'})", function(error, stdout, stderr) { console.log("controller stopped"); 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); //controlar que solo se haga un arranque por vez y agregar el exec 3>fifo - child0 = exec("cd /home/pi && echo \""+request+"\" > data", function(error, stdout, stderr) { + child0 = exec("cd /home/pi/scripts && echo \""+request+"\" > data", function(error, stdout, stderr) { console.log(stdout + stderr); answer+=stdout; }); - child1 = exec("cd /home/pi && mkfifo fifo && rm aichivo && 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; }); - child2 = exec("exec 3>fifo", function(error, stdout, stderr) { + child2 = exec("cd /home/pi/scripts && exec 3>fifo", function(error, stdout, stderr) { console.log(stdout + stderr); answer+=stdout; }); + + //child3 uses tail so it can read from fifo even after a EOF - child3 = exec("cd /home/pi && tail -n +1 -f fifo | sudo ./clusterGRE.py > aichivo 2>&1 &", function(error, stdout, stderr) { + 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); answer+=stdout; }); @@ -199,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; @@ -206,25 +312,25 @@ router.get('/stopvsorc', (req,res) =>{ var child3; var payload console.log("erasing..."); - child1 = exec("cd /home/pi && 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 && ./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;