This repository has been archived by the owner on Feb 5, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathserver.js
102 lines (85 loc) · 2.76 KB
/
server.js
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
// npm install ws en jsftp
var sys = require("sys"),
fs = require("fs"),
Ftp = require("jsftp"),
WebSocketServer = require('ws').Server;
function hour() { return new Date().getHours(); };
var wss = new WebSocketServer({port: 8080});
var clients = [];
var snapshotHour = -1; // start auto-capping the history feed.
var imageName = "image.jpg";
function convertDataURIToBinary(dataURI) {
var BASE64_MARKER = ';base64,';
var base64Index = dataURI.indexOf(BASE64_MARKER) + BASE64_MARKER.length;
var base64 = dataURI.substring(base64Index);
return new Buffer(base64, 'base64'); // atob(base64) in window scope
}
function reuploadImage() {
var user = "FILL ME IN";
var pass = "FILL ME IN";
var rootPath = "/domains/brainbaking.com/public_html/cam/";
var ftp = new Ftp({
host: "ftp.brainbaking.com",
port: 21
});
ftp.auth(user, pass, function(err, res) {
function uploadImageTo(path, callback) {
ftp.put(imageName, path, function(err, data) {
if(err) {
sys.debug("ERROR while uploading");
sys.debug(err);
} else {
sys.debug("file uploaded to " + path + " - callback firing...");
callback(data);
}
});
}
function uploadSnapshotIndexFile() {
var images = { files: [] };
ftp.ls(rootPath, function(err, list) {
images.files = list.filter(function(file) {
return file.name.indexOf('.jpg') > 0 && file.name.indexOf('_') > 0;
});
fs.writeFile("index.json", JSON.stringify(images), function(e) {
if(e) throw e;
ftp.put("index.json", rootPath + "index.json", function(e) {
if(e) throw e;
sys.debug("written index JSON file.");
});
});
});
}
function createHistorySnapshotIfNeeded() {
if(hour() !== snapshotHour) {
sys.debug("Hourly snapshot needs refreshment, creating...");
snapshotHour = hour();
uploadImageTo(rootPath + new Date().getTime() + "_" + imageName, uploadSnapshotIndexFile);
}
}
uploadImageTo(rootPath + imageName, createHistorySnapshotIfNeeded);
});
}
wss.on('connection', function(ws) {
sys.debug("connected client");
clients.push(ws);
ws.on('message', function(message) {
sys.debug('received data - broadcasting back to client...');
fs.writeFile(imageName, convertDataURIToBinary(message), function(e) {
if(e) {
sys.debug(e);
} else {
sys.debug("file written, starting upload...");
reuploadImage();
}
});
clients.forEach(function(client) {
try {
client.send(message);
} catch(notOpenEx) {
// should I remove the client? Can I do a check instead of try/catch?
sys.debug("client not connected anymore, ignoring exception");
}
});
});
});
sys.debug("Listening on port 8080");