-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
104 lines (89 loc) · 2.66 KB
/
server.js
File metadata and controls
104 lines (89 loc) · 2.66 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
var express = require("express");
var bodyParser = require("body-parser");
var Promise = require('bluebird');
var multer = require("multer");
var http = require("http");
var mv = require('mv');
var exec = require('child_process').execFile;
var path = require("path");
function promiseFromChildProcess(child) {
return new Promise(function(resolve, reject){
child.addListner("error", reject);
child.addListner("exit", resolve);
});
}
var app = express();
app.use(bodyParser.json());
app.use(express.static(path.join(__dirname, "results")));
var httpServer = http.createServer(app).listen(8088, function(req, res){
console.log("Socket IO Server has been started at 8088");
});
var io = require("socket.io").listen(httpServer);
var storage = multer.diskStorage({
destination: function(req, file, callback){
callback(null, './uploads');
},
filename: function(req, file, callback){
callback(null, file.fieldname + "-" + Date.now());
}
});
var upload = multer({storage: storage}).array('userPhoto', 255);
app.get('/', function(req,res){
res.sendFile(__dirname + "/index.html");
});
io.sockets.on('connection', function(socket){
console.log("connected!");
socket.emit("connected", { msg: "connected!"});
socket.on('forceDisconnect', function() {
socket.disconnect();
});
socket.on('disconnect', function() {
console.log('user disconnected: ' + socket.name);
});
});
app.post('/api/photo', function(req, res){
upload(req, res, function(err){
if(err){
return res.end("error");
} else {
var imgArr = [];
for(var i=0; i < req.files.length; i++){
imgArr[i] = req.files[i].path;
}
var child = exec('./image-stitching', imgArr);
promiseFromChildProcess(child).then(function (result) {
console.log('promise complete: ' + result);
}, function (err) {
console.log('promise rejected: ' + err);
});
child.stdout.on('data', function (data) {
io.sockets.emit("logs", { msg: data});
console.log('stdout: ' + data);
});
child.stderr.on('data', function (data) {
console.log('stderr: ' + data);
});
child.on('close', function (code) {
var filename = "results/"+Date.now() + "-" +"out.jpg"
console.log(filename);
mv("out.jpg", filename, function(err){
if(err){
console.log();
io.sockets.emit("logs", { msg: 'err: ' + err});
return err;
}
console.log(filename);
io.sockets.emit("imgsrc", { msg: filename.replace("results/", "")});
console.log('closing code: ' + code);
});
});
io.sockets.emit("logs", { msg: "Upload success!"});
res.end("Upload success!");
}
});
});
/*
app.listen(3000, function(){
console.log("working on port 3000");
});
*/