X-Git-Url: https://git.josue.xyz/?a=blobdiff_plain;f=src%2Froutes%2Findex.js;h=45b7350110bd29d50c4244f52fcf3726d6be81b8;hb=52a99203812259e814afb138a8692a3f3892591d;hp=0edbab63a433627b90f103c3532e420c0f1eea54;hpb=136b34b6f8d023c672f832fc61ea70ccba216f94;p=VSoRC%2F.git diff --git a/src/routes/index.js b/src/routes/index.js index 0edbab6..45b7350 100644 --- a/src/routes/index.js +++ b/src/routes/index.js @@ -3,24 +3,37 @@ const { } = require('express'); const router = new Router(); -let alumnos = []; +//renders de las paginas web router.get("/", (req, res) => { - res.render("index", { - alumnos - }) + res.render("index") }); -router.get("/flex", (req, res) => { - res.render("flex") +router.get("/access", (req, res) => { + res.render("access") }); +router.get("/starter", (req, res) => { + res.render("starter") +}); + +router.get("/stats", (req, res) => { + res.render("stats") +}); +router.get("/topology", (req, res) => { + res.render("topology") +}); + +router.get("/topologyMaker", (req, res) => { + res.render("topologyMaker") +}); +//en lo adelante se encuentran las peticiones de datos 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); }); @@ -31,7 +44,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); }); @@ -42,11 +55,185 @@ 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('/gettopo', (req, res) => { + var sys = require('sys') + var exec = require('child_process').exec; + var child; + child = exec("curl localhost:8080/topology", function(error, stdout, stderr) { + console.log("gettopo"); + 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/scripts && echo pingall > fifo", function(error, stdout, stderr) { + console.log("pingall"); + res.send(stdout); + }); +}); +router.get('/placement', (req, res) => { + var sys = require('sys') + var exec = require('child_process').exec; + var child; + 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/scripts && cat aichivo 2>&1", function(error, stdout, stderr) { + console.log("getting vsorc data"); + res.send(stdout); + }); +}); +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) { + console.log("getting controller data"); + res.send(stdout); + }); +}); +router.get('/listswitch', (req, res) => { + var sys = require('sys') + var exec = require('child_process').exec; + var child; + child = exec("curl localhost:8080/data?list=switches", function(error, stdout, stderr) { + console.log("listswitch"); + console.log(stdout); + let value = ''; + try { + value = JSON.parse(stdout) + } + catch(error) { + console.error(error); + console.log("no response from server"); + // expected output: ReferenceError: nonExistentFunction is not defined + // Note - error messages will vary depending on browser + } + + res.send(value); + }); +}); + +router.get('/status', (req, res) => { + var sys = require('sys') + var exec = require('child_process').exec; + var child; + console.log(req.query.status+req.query.dpid); + child = exec("curl \"localhost:8080/status?status="+req.query.status+"&dpid="+req.query.dpid+"\"", function(error, stdout, stderr) { + console.log("statusFlows"); + console.log(stdout); + let value = JSON.parse(stdout) + + res.send(value); + }); +}); + + +router.get('/startcontroller', (req, res) => { + 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/scripts && touch controllerout && ./ejecutarcontroller.sh > controllerout 2>&1 &", function(error, stdout, stderr) { + console.log("controller started"); + res.send(stdout); + }); +}); + +router.get('/stopcontroller', (req, res) => { + var sys = require('sys') + var exec = require('child_process').exec; + var child; + 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('/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 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/scripts && echo \""+request+"\" > data", function(error, stdout, stderr) { + console.log(stdout + stderr); + answer+=stdout; + }); + child1 = exec("cd /home/pi/scripts && mkfifo fifo && touch aichivo", function(error, stdout, stderr) { + console.log(stdout + stderr); + answer+=stdout; + }); + 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/scripts && tail -n +1 -f fifo | sudo ./clusterGRE.py > aichivo 2>&1 &", function(error, stdout, stderr) { + console.log(stdout + stderr); + answer+=stdout; + }); + res.send(answer); +}); + +router.get('/stopvsorc', (req,res) =>{ + var sys = require('sys') + var exec = require('child_process').exec; + var child1; + var child2; + var child3; + var payload + console.log("erasing..."); + child1 = exec("cd /home/pi/scripts && exec 3>&- && rm fifo && rm aichivo", 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) { + 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; + + }); + res.send(payload); +}); module.exports = router;