Files
cloudron-box/src/domaindb.js

126 lines
4.4 KiB
JavaScript
Raw Normal View History

2017-10-28 21:42:32 +02:00
/* jslint node:true */
'use strict';
exports = module.exports = {
add: add,
get: get,
getAll: getAll,
update: update,
upsert: upsert,
2017-10-28 21:42:32 +02:00
del: del,
2017-11-11 03:06:57 +01:00
_clear: clear,
_addDefaultDomain: addDefaultDomain
2017-10-28 21:42:32 +02:00
};
var assert = require('assert'),
database = require('./database.js'),
DatabaseError = require('./databaseerror'),
2017-11-11 03:06:57 +01:00
config = require('./config.js'),
2017-10-28 21:42:32 +02:00
safe = require('safetydance');
function postProcess(data) {
data.config = safe.JSON.parse(data.configJson);
delete data.configJson;
2017-10-28 21:42:32 +02:00
return data;
}
function get(domain, callback) {
assert.strictEqual(typeof domain, 'string');
assert.strictEqual(typeof callback, 'function');
database.query('SELECT * FROM domains WHERE domain=?', [ domain ], function (error, result) {
if (error) return callback(new DatabaseError(DatabaseError.INTERNAL_ERROR, error));
if (result.length === 0) return callback(new DatabaseError(DatabaseError.NOT_FOUND));
postProcess(result[0]);
callback(null, result[0]);
});
}
function getAll(callback) {
database.query('SELECT * FROM domains ORDER BY domain', function (error, results) {
if (error) return callback(new DatabaseError(DatabaseError.INTERNAL_ERROR, error));
results.forEach(postProcess);
callback(null, results);
});
}
2018-01-09 14:46:38 -08:00
function add(domain, zoneName, provider, config, callback) {
2017-10-28 21:42:32 +02:00
assert.strictEqual(typeof domain, 'string');
assert.strictEqual(typeof zoneName, 'string');
2018-01-09 14:46:38 -08:00
assert.strictEqual(typeof provider, 'string');
2017-10-28 21:42:32 +02:00
assert.strictEqual(typeof config, 'object');
assert.strictEqual(typeof callback, 'function');
2018-01-09 14:46:38 -08:00
database.query('INSERT INTO domains (domain, zoneName, provider, configJson) VALUES (?, ?, ?, ?)', [ domain, zoneName, provider, JSON.stringify(config) ], function (error) {
2017-10-28 21:42:32 +02:00
if (error && error.code === 'ER_DUP_ENTRY') return callback(new DatabaseError(DatabaseError.ALREADY_EXISTS, error));
if (error) return callback(new DatabaseError(DatabaseError.INTERNAL_ERROR, error));
callback(null);
});
}
2018-01-09 14:46:38 -08:00
function upsert(domain, zoneName, provider, config, callback) {
assert.strictEqual(typeof domain, 'string');
assert.strictEqual(typeof zoneName, 'string');
2018-01-09 14:46:38 -08:00
assert.strictEqual(typeof provider, 'string');
assert.strictEqual(typeof config, 'object');
assert.strictEqual(typeof callback, 'function');
2018-01-09 14:46:38 -08:00
database.query('REPLACE INTO domains (domain, zoneName, provider, configJson) VALUES (?, ?, ?, ?)', [ domain, zoneName, provider, JSON.stringify(config) ], function (error) {
if (error) return callback(new DatabaseError(DatabaseError.INTERNAL_ERROR, error));
callback(null);
});
}
2018-01-09 14:46:38 -08:00
function update(domain, provider, config, callback) {
2017-10-28 21:42:32 +02:00
assert.strictEqual(typeof domain, 'string');
2018-01-09 14:46:38 -08:00
assert.strictEqual(typeof provider, 'string');
2017-10-28 21:42:32 +02:00
assert.strictEqual(typeof config, 'object');
assert.strictEqual(typeof callback, 'function');
2018-01-09 14:46:38 -08:00
database.query('UPDATE domains SET provider=?, configJson=? WHERE domain=?', [ provider, JSON.stringify(config), domain ], function (error) {
2017-10-28 21:42:32 +02:00
if (error && error.reason === DatabaseError.NOT_FOUND) return callback(new DatabaseError(DatabaseError.NOT_FOUND));
if (error) return callback(new DatabaseError(DatabaseError.INTERNAL_ERROR, error));
callback(null);
});
}
function del(domain, callback) {
assert.strictEqual(typeof domain, 'string');
assert.strictEqual(typeof callback, 'function');
database.query('DELETE FROM domains WHERE domain=?', [ domain ], function (error, result) {
if (error && error.code === 'ER_ROW_IS_REFERENCED_2') return callback(new DatabaseError(DatabaseError.IN_USE));
2017-10-28 21:42:32 +02:00
if (error) return callback(new DatabaseError(DatabaseError.INTERNAL_ERROR, error));
if (result.affectedRows !== 1) return callback(new DatabaseError(DatabaseError.NOT_FOUND));
callback(null);
});
}
function clear(callback) {
database.query('DELETE FROM domains', function (error) {
if (error) return callback(new DatabaseError(DatabaseError.INTERNAL_ERROR, error));
callback(error);
});
}
2017-11-11 03:06:57 +01:00
function addDefaultDomain(callback) {
assert(config.fqdn(), 'no fqdn set in config, cannot continue');
2018-01-09 14:46:38 -08:00
add(config.fqdn(), config.zoneName(), 'manual', { }, function (error) {
2017-11-11 03:06:57 +01:00
if (error && error.reason !== DatabaseError.ALREADY_EXISTS) return callback(error);
callback();
});
}