-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathmetaparticle-mysql-storage.js
87 lines (79 loc) · 2.5 KB
/
metaparticle-mysql-storage.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
var mysql = require('mysql');
var q = require('q');
var connection = null;
module.exports.configure = function (config) {
if (config) {
connection = mysql.createConnection(config);
} else {
connection = mysql.createConnection({
host : 'localhost',
user : 'root',
database : 'data'
});
}
connection.connect();
connection.query('create table if not exists records (name varchar(256) primary key, version int, data text);', (error) => {
if (error) {
throw error;
}
});
};
module.exports.load = function (scope) {
var deferred = q.defer();
connection.query('select version, data from records where name=\'' + scope + '\'', (error, results) => {
if (error) {
throw error;
}
if (results.length == 0) {
deferred.resolve({
'data': {},
'version': 'empty'
});
return;
}
var obj = JSON.parse(results[0].data);
obj.version = results[0].version;
deferred.resolve(obj);
});
return deferred.promise;
}
/**
* Store the data to persistent storage.
* @param {string} scope The scope to store
* @param {data} data The data package
* @returns A promise that resolves to true if the storage succeeded, false otherwise.
*/
module.exports.store = function (scope, data) {
var deferred = q.defer();
if (data.version == 'empty') {
var sql = mysql.format('insert into records (name, version, data) values (?, ?, ?);', [scope, 1, JSON.stringify(data)]);
connection.query(sql, (error) => {
if (error) {
if (error.code == 'ER_DUP_ENTRY') {
deferred.resolve(false);
return;
}
throw(error);
}
deferred.resolve(true);
});
} else {
var oldVersion = data.version;
data.version++;
var sql = mysql.format('update records set data=?, version=? where (name=? and version=?) ', [JSON.stringify(data), data.version, scope, oldVersion]);
connection.query(sql, (error, results) => {
if (error) {
throw(error);
}
if (results.affectedRows != 1) {
deferred.resolve(false);
return;
}
deferred.resolve(true);
})
}
return deferred.promise;
};
module.exports.shutdown = () => {
connection.end();
}