Se trabajo mas en la vista de stats
[VSoRC/.git] / src / routes / index.js
1 const {
2   Router
3 } = require('express');
4 const router = new Router();
5
6
7 //renders de las paginas web
8 router.get("/", (req, res) => {
9   res.render("index")
10 });
11
12 router.get("/access", (req, res) => {
13   res.render("access")
14 });
15
16 router.get("/starter", (req, res) => {
17   res.render("starter")
18 });
19
20 router.get("/stats", (req, res) => {
21   res.render("stats")
22 });
23
24 router.get("/topology", (req, res) => {
25   res.render("topology")
26 });
27
28 router.get("/topologyMaker", (req, res) => {
29   res.render("topologyMaker")
30 });
31 //en lo adelante se encuentran las peticiones de datos
32 router.get('/free', (req, res) => {
33   var sys = require('sys')
34   var exec = require('child_process').exec;
35   var child;
36   child = exec("free -b | grep Mem |  awk  '{print $7}'", function(error, stdout, stderr) {
37     console.log("free");
38     res.send(stdout);
39   });
40 });
41
42
43 router.get('/mpstat', (req, res) => {
44   var sys = require('sys')
45   var exec = require('child_process').exec;
46   var child;
47   child = exec("mpstat 1 1| grep all | awk '{print $13}'", function(error, stdout, stderr) {
48     console.log("mpstat");
49     res.send(stdout);
50   });
51 });
52
53
54 router.get('/ifstat', (req, res) => {
55   var sys = require('sys')
56   var exec = require('child_process').exec;
57   var child;
58   child = exec("ifstat -n -b -i wlp2s0  0.3 1 | grep [0-9]$", function(error, stdout, stderr) {
59     console.log("ifstat");
60     res.send(stdout);
61   });
62 });
63
64 router.get('/gettopo', (req, res) => {
65   var sys = require('sys')
66   var exec = require('child_process').exec;
67   var child;
68   child = exec("curl localhost:8080/topology", function(error, stdout, stderr) {
69     console.log("gettopo");
70     res.send(stdout);
71   });
72 });
73
74 router.get('/listswitch', (req, res) => {
75   var sys = require('sys')
76   var exec = require('child_process').exec;
77   var child;
78   child = exec("curl localhost:8080/data?list=switches", function(error, stdout, stderr) {
79     console.log("listswitch");
80     console.log(stdout);
81     let value = JSON.parse(stdout)
82
83     res.send(value);
84   });
85 });
86
87 router.get('/status', (req, res) => {
88   var sys = require('sys')
89   var exec = require('child_process').exec;
90   var child;
91   console.log(req.query.status+req.query.dpid);
92   child = exec("curl \"localhost:8080/status?status="+req.query.status+"&dpid="+req.query.dpid+"\"", function(error, stdout, stderr) {
93     console.log("statusFlows");
94     console.log(stdout);
95     let value = JSON.parse(stdout)
96
97     res.send(value);
98   });
99 });
100
101
102 router.get('/startcontroller', (req, res) => {
103   var sys = require('sys')
104   var exec = require('child_process').exec;
105   var child;
106   child = exec("cd /home/pi/ryu && setsid $(cat /home/pi/ryu/ejecutarcontroller.sh | grep sudo) >/dev/null 2>&1 < /dev/null &", function(error, stdout, stderr) {
107     console.log("controller started");
108     res.send(stdout);
109   });
110 });
111
112 router.get('/stopcontroller', (req, res) => {
113   var sys = require('sys')
114   var exec = require('child_process').exec;
115   var child;
116   child = exec("sudo kill $(ps aux | grep python | grep ryu | awk {'print $2'})", function(error, stdout, stderr) {
117     console.log("controller stopped");
118     res.send(stdout);
119   });
120 });
121
122 router.get('/startvsorc', (req, res) => {
123   var sys = require('sys')
124   var exec = require('child_process').exec;
125   var child0;//needs a mkfifo named fifo to exist
126   var child1;
127   var child2;
128   var answer;
129   //controlar que solo se haga un arranque por vez y agregar el exec 3>fifo
130   child0 = exec("cd /home/pi && mkfifo fifo && touch aichivo", function(error, stdout, stderr) {
131     console.log(stdout + stderr);
132     answer+=stdout;
133   });
134   child1 = exec("exec 3>fifo", function(error, stdout, stderr) {
135     console.log(stdout + stderr);
136     answer+=stdout;
137   });//add disown?
138   child2 = exec("cd /home/pi && cat fifo | sudo ./clusterGRE.py > aichivo 2>&1 &", function(error, stdout, stderr) {
139     console.log(stdout + stderr);
140     answer+=stdout;
141   });
142   res.send(answer);
143 });
144
145 router.get('/stopvsorc', (req,res) =>{
146   var sys = require('sys')
147   var exec = require('child_process').exec;
148   var child;
149   child = exec("cd /home/pi && exec 3>&- && rm fifo aichivo", function(error, stdout, stderr) {
150     console.log(stdout);
151     res.send(stdout);
152   });//esto cierra el fifo, lo cual cierra el programa
153 });
154 module.exports = router;