-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathserver.js
98 lines (81 loc) · 2.12 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
var level = require('level');
var strftime = require('strftime');
var siteCrawler = require('./siteCrawler');
var testCrawler = require('./testCrawler');
// setup dB
var mysql = require('mysql');
var pool = mysql.createPool({
connectionLimit : 10,
host : 'localhost',
user : 'classplanner',
password : 'stackedqueue',
database : 'class_planner'
});
/*
connection.connect(function(err) {
if(err) {
console.error('error connecting: ' + err.stack);
return;
}
console.log('connected as id ' + connection.threadId);
});
*/
/*
var sql = 'SELECT * FROM majors';
connection.query("INSERT INTO majors (major_code, major_name) VALUES ('code', 'name')");
connection.query(sql, function(err, results) {
if(err)
console.log(err);
else
console.log(results);
});
*/
var curDate = strftime('%F');
var count = 0;
//var db = sublevel(level('./testdb' + curDate));
//var curTimeDb = db.sublevel(curDate);
//
//
var testNum = 0;
var steps = [
connectionWrapper(siteCrawler.updateMajorList),
connectionWrapper(siteCrawler.updateMajorCourses),
connectionWrapper(testCrawler.printMajors),
cleanUp
];
function connectionWrapper(fun) {
return function() {
pool.getConnection(function(err, connection) {
if(err) {
console.log(err);
return;
}
console.log('got connection!');
fun(connection);
console.log('releasing connection!');
connection.release();
});
};
}
function executeStepWrapper(step, callback) {
step();
callback();
}
function cleanUp() {
console.log('Executing cleanUp');
}
function executeSteps(step) {
console.log(count);
count++;
if(step) {
//console.log('Executing step: ' + step);
executeStepWrapper(step, function() {
return executeSteps(steps.shift());
});
} else {
}
}
executeSteps(steps.shift());
//siteCrawler.updateMajorList(db);
//testCrawler.printMajors(db);
//connection.end();