Files
cloudron-box/src/eventlogdb.js

136 lines
4.6 KiB
JavaScript
Raw Normal View History

2016-04-29 23:37:54 -07:00
'use strict';
exports = module.exports = {
get: get,
getAllPaged: getAllPaged,
getByCreationTime: getByCreationTime,
2016-04-29 23:37:54 -07:00
add: add,
count: count,
2016-07-25 12:36:43 -07:00
delByCreationTime: delByCreationTime,
2016-04-29 23:37:54 -07:00
_clear: clear
};
var assert = require('assert'),
database = require('./database.js'),
DatabaseError = require('./databaseerror'),
mysql = require('mysql'),
2016-07-25 12:36:43 -07:00
safe = require('safetydance'),
util = require('util');
2016-04-29 23:37:54 -07:00
2016-04-30 12:41:27 -07:00
var EVENTLOGS_FIELDS = [ 'id', 'action', 'source', 'data', 'creationTime' ].join(',');
2016-04-29 23:37:54 -07:00
function postProcess(eventLog) {
// usually we have sourceJson and dataJson, however since this used to be the JSON data type, we don't
2016-04-30 12:41:27 -07:00
eventLog.source = safe.JSON.parse(eventLog.source);
2016-04-30 09:51:23 -07:00
eventLog.data = safe.JSON.parse(eventLog.data);
2016-04-29 23:37:54 -07:00
return eventLog;
}
function get(eventId, callback) {
assert.strictEqual(typeof eventId, 'string');
assert.strictEqual(typeof callback, 'function');
database.query('SELECT ' + EVENTLOGS_FIELDS + ' FROM eventlog WHERE id = ?', [ eventId ], function (error, result) {
if (error) return callback(new DatabaseError(DatabaseError.INTERNAL_ERROR, error));
if (result.length === 0) return callback(new DatabaseError(DatabaseError.NOT_FOUND));
callback(null, postProcess(result[0]));
});
}
function getAllPaged(actions, search, page, perPage, callback) {
assert(Array.isArray(actions));
assert(typeof search === 'string' || search === null);
assert.strictEqual(typeof page, 'number');
assert.strictEqual(typeof perPage, 'number');
assert.strictEqual(typeof callback, 'function');
var data = [];
var query = 'SELECT ' + EVENTLOGS_FIELDS + ' FROM eventlog';
if (actions.length || search) query += ' WHERE';
2016-11-28 16:02:18 +01:00
if (search) query += ' (source LIKE ' + mysql.escape('%' + search + '%') + ' OR data LIKE ' + mysql.escape('%' + search + '%') + ')';
if (actions.length && search) query += ' AND ( ';
actions.forEach(function (action, i) {
query += ' (action LIKE ' + mysql.escape(`%${action}%`) + ') ';
if (i < actions.length-1) query += ' OR ';
});
if (actions.length && search) query += ' ) ';
query += ' ORDER BY creationTime DESC LIMIT ?,?';
data.push((page-1)*perPage);
data.push(perPage);
database.query(query, data, function (error, results) {
if (error) return callback(new DatabaseError(DatabaseError.INTERNAL_ERROR, error));
2017-07-21 16:13:44 +02:00
results.forEach(postProcess);
callback(null, results);
});
}
function getByCreationTime(creationTime, callback) {
assert(util.isDate(creationTime));
2017-07-21 16:13:44 +02:00
assert.strictEqual(typeof callback, 'function');
2017-11-08 09:14:44 -08:00
var query = 'SELECT ' + EVENTLOGS_FIELDS + ' FROM eventlog WHERE creationTime >= ? ORDER BY creationTime DESC';
database.query(query, [ creationTime ], function (error, results) {
2017-07-21 16:13:44 +02:00
if (error) return callback(new DatabaseError(DatabaseError.INTERNAL_ERROR, error));
results.forEach(postProcess);
callback(null, results);
});
}
2016-04-30 12:41:27 -07:00
function add(id, action, source, data, callback) {
2016-04-29 23:37:54 -07:00
assert.strictEqual(typeof id, 'string');
assert.strictEqual(typeof action, 'string');
2016-04-30 12:41:27 -07:00
assert.strictEqual(typeof source, 'object');
2016-04-29 23:37:54 -07:00
assert.strictEqual(typeof data, 'object');
assert.strictEqual(typeof callback, 'function');
2016-04-30 12:41:27 -07:00
database.query('INSERT INTO eventlog (id, action, source, data) VALUES (?, ?, ?, ?)', [ id, action, JSON.stringify(source), JSON.stringify(data) ], function (error, result) {
2016-04-29 23:37:54 -07:00
if (error && error.code === 'ER_DUP_ENTRY') return callback(new DatabaseError(DatabaseError.ALREADY_EXISTS, error));
if (error || result.affectedRows !== 1) return callback(new DatabaseError(DatabaseError.INTERNAL_ERROR, error));
callback(null);
});
}
function count(callback) {
assert.strictEqual(typeof callback, 'function');
database.query('SELECT COUNT(*) AS total FROM eventlog', function (error, result) {
if (error) return callback(new DatabaseError(DatabaseError.INTERNAL_ERROR, error));
return callback(null, result[0].total);
});
}
function clear(callback) {
database.query('DELETE FROM eventlog', function (error) {
if (error) return callback(new DatabaseError(DatabaseError.INTERNAL_ERROR, error));
callback(error);
});
}
2016-04-30 09:51:23 -07:00
function delByCreationTime(creationTime, callback) {
2016-07-25 12:36:43 -07:00
assert(util.isDate(creationTime));
assert.strictEqual(typeof callback, 'function');
var query = 'DELETE FROM eventlog WHERE creationTime < ?';
database.query(query, [ creationTime ], function (error) {
2016-07-25 12:36:43 -07:00
if (error) return callback(new DatabaseError(DatabaseError.INTERNAL_ERROR, error));
callback(error);
});
}