-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwatch-34.js
106 lines (89 loc) · 2.67 KB
/
watch-34.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
103
104
105
106
/*
* Make one file per Cluster to be Synced.
*/
var fs = require('fs');
var chokidar = require('chokidar');
var mysql = require('mysql');
var config = require('./config.json');
var ftpcluster = "34";
var pool = mysql.createPool( config.database );
var dirs = ["/Volumes/cluster34/"];
/*
for (var i = 0; i < 200; i++) {
dirs.push("/Volumes/cluster34/" + i +"/");
}
//console.log(dirs);
fs.readdir("/Volumes/cluster34/", function(err, files){
console.log(files);
});
*/
var walk = function(dir, done) {
var results = [];
fs.readdir(dir, function(err, list) {
if (err) return done(err);
var pending = list.length;
if (!pending) return done(null, results);
list.forEach(function(file) {
file = dir + '/' + file;
//console.log(file);
fs.stat(file, function(err, stat) {
if (stat && stat.isDirectory()) {
walk(file, function(err, res) {
results = results.concat(res);
if (!--pending) done(null, results);
});
} else {
results.push(file);
//console.log(results.length);
pool.getConnection(function(err, connection) {
if (err){ console.log(err); }
connection.query('SELECT * FROM ftp_aws_index WHERE ftp LIKE ?', file, function(err, rows, fields) {
if (err){ console.log(err); }
if(!rows[0]){
console.log("add "+ file);
connection.query("INSERT INTO ftp_aws_index SET ?", { ftp: file , cluster: ftpcluster });
//console.log('File', file, 'has been added');
} else {
console.log("skip "+ file);
}
});
connection.end();
});
if (!--pending) done(null, results);
}
});
});
});
};
/*
walk("/Volumes/cluster34/1", function(err, results) {
if (err) throw err;
console.log(results);
});
*/
walk("/Volumes/cluster34", function(err, results) {
if (err) throw err;
console.log(results.length);
});
/*
var watcher = chokidar.watch( dirs , {ignoreInitial: false, persistent: true});
watcher
.on('add', function(path) {
console.log(path);
pool.getConnection(function(err, connection) {
if (err){ console.log(err); }
connection.query('SELECT * FROM ftp_aws_index WHERE ftp = ?', path, function(err, rows, fields) {
if (err){ console.log(err); }
if(!rows[0]){
connection.query("INSERT INTO ftp_aws_index SET ?", { ftp: path , cluster: ftpcluster });
console.log('File', path, 'has been added');
}
});
connection.end();
});
})
.on('change', function(path) {console.log('File', path, 'has been changed');})
.on('unlink', function(path) {console.log('File', path, 'has been removed');})
.on('error', function(error) {console.error('Error happened', error);})
watcher.close();
*/