initializer buttons done but missing some details
[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 $3}'", 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 | grep Average | awk '{print $12}'", 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 eth0  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('/iperf', (req, res) => {
75   var sys = require('sys')
76   var exec = require('child_process').exec;
77   var child;
78   child = exec("cd /home/pi && echo iperf > fifo", function(error, stdout, stderr) {
79     console.log("pingall");
80     res.send(stdout);
81   });
82 });
83 router.get('/pingall', (req, res) => {
84   var sys = require('sys')
85   var exec = require('child_process').exec;
86   var child;
87   child = exec("cd /home/pi && echo pingall > fifo", function(error, stdout, stderr) {
88     console.log("pingall");
89     res.send(stdout);
90   });
91 });
92 router.get('/placement', (req, res) => {
93   var sys = require('sys')
94   var exec = require('child_process').exec;
95   var child;
96   child = exec("cd /home/pi && echo placement > fifo", function(error, stdout, stderr) {
97     console.log("placement");
98     res.send(stdout);
99   });
100 });
101
102 router.get('/getvsorcdata', (req, res) => {
103   var sys = require('sys')
104   var exec = require('child_process').exec;
105   var child;
106   child = exec("cd /home/pi && cat aichivo 2>&1", function(error, stdout, stderr) {
107     console.log("getting vsorc data");
108     res.send(stdout);
109   });
110 });
111 router.get('/getcontrollerdata', (req, res) => {
112   var sys = require('sys')
113   var exec = require('child_process').exec;
114   var child;
115   child = exec("cd /home/pi && cat controllerout 2>&1", function(error, stdout, stderr) {
116     console.log("getting controller data");
117     res.send(stdout);
118   });
119 });
120 router.get('/listswitch', (req, res) => {
121   var sys = require('sys')
122   var exec = require('child_process').exec;
123   var child;
124   child = exec("curl localhost:8080/data?list=switches", function(error, stdout, stderr) {
125     console.log("listswitch");
126     console.log(stdout);
127     let value = '';
128     try {
129       value = JSON.parse(stdout)
130     }
131     catch(error) {
132       console.error(error);
133       console.log("no response from server");
134       // expected output: ReferenceError: nonExistentFunction is not defined
135       // Note - error messages will vary depending on browser
136     }
137
138     res.send(value);
139   });
140 });
141
142 router.get('/status', (req, res) => {
143   var sys = require('sys')
144   var exec = require('child_process').exec;
145   var child;
146   console.log(req.query.status+req.query.dpid);
147   child = exec("curl \"localhost:8080/status?status="+req.query.status+"&dpid="+req.query.dpid+"\"", function(error, stdout, stderr) {
148     console.log("statusFlows");
149     console.log(stdout);
150     let value = JSON.parse(stdout)
151
152     res.send(value);
153   });
154 });
155
156
157 router.get('/startcontroller', (req, res) => {
158   var sys = require('sys')
159   var exec = require('child_process').exec;
160   var child;
161   //cd /home/pi && setsid $(cat /home/pi/ejecutarcontroller.sh | grep sudo) >/dev/null 2>&1 < /dev/null &
162   //cd /home/pi && ./ejecutarcontroller.sh > /dev/null 2>&1 < /dev/null &  //comando anterior
163   child = exec("cd /home/pi && touch controllerout && ./ejecutarcontroller.sh > controllerout 2>&1 &", function(error, stdout, stderr) {
164     console.log("controller started");
165     res.send(stdout);
166   });
167 });
168
169 router.get('/stopcontroller', (req, res) => {
170   var sys = require('sys')
171   var exec = require('child_process').exec;
172   var child;
173   child = exec("cd /home/pi && rm controllerout && sudo kill $(ps aux | grep python | grep ryu | awk {'print $2'})", function(error, stdout, stderr) {
174     console.log("controller stopped");
175     res.send(stdout);
176   });
177 });
178
179 router.get('/startvsorc', (req, res) => {
180   var sys = require('sys')
181   var exec = require('child_process').exec;
182   var child0;//needs a mkfifo named fifo to exist
183   var child1;
184   var child2;
185   var child3;
186   var answer;
187   request = JSON.parse(req.query.topology)
188   console.log("Topology is : \n"+ request);
189   //controlar que solo se haga un arranque por vez y agregar el exec 3>fifo
190   child0 = exec("cd /home/pi && echo \""+request+"\" > data", function(error, stdout, stderr) {
191     console.log(stdout + stderr);
192     answer+=stdout;
193   });
194   child1 = exec("cd /home/pi && mkfifo fifo && touch aichivo", function(error, stdout, stderr) {
195     console.log(stdout + stderr);
196     answer+=stdout;
197   });
198   child2 = exec("exec 3>fifo", function(error, stdout, stderr) {
199     console.log(stdout + stderr);
200     answer+=stdout;
201   });
202   //child3 uses tail so it can read from fifo even after a EOF
203   child3 = exec("cd /home/pi && tail -n +1 -f fifo | sudo ./clusterGRE.py > aichivo 2>&1 &", function(error, stdout, stderr) {
204     console.log(stdout + stderr);
205     answer+=stdout;
206   });
207   res.send(answer);
208 });
209
210 router.get('/stopvsorc', (req,res) =>{
211   var sys = require('sys')
212   var exec = require('child_process').exec;
213   var child1;
214   var child2;
215   var child3;
216   var payload
217   console.log("erasing...");
218   child1 = exec("cd /home/pi && exec 3>&- && rm fifo && rm aichivo", function(error, stdout, stderr) {
219     console.log(stdout);
220
221     payload+="rm done\n\n"+stdout;
222   });//esto cierra el fifo, lo cual cierra el programa
223
224   //sudo kill $(ps aux | grep GRE| grep sudo|awk {'print $2'}) && cd /home/pi && ./multissh.sh sudo -E mn -c; sudo -E mn -c
225   console.log("killing all...");
226   child2 = exec("sudo kill $(ps aux | grep GRE| grep sudo|awk {'print $2'})", function(error, stdout, stderr) {
227     console.log(stdout);
228     payload+="killed\n\n"+stdout;
229   });
230   console.log("Multisshing and cleaning...");
231   child3 = exec("cd /home/pi && ./multissh.sh sudo -E mn -c; sudo -E mn -c", function(error, stdout, stderr) {
232     console.log(stdout);
233     console.log("multisshed");
234     payload+="Multisshed\n\n"+stdout;
235
236   });
237   res.send(payload);
238 });
239 module.exports = router;