hedera-web/js/db/connection.js

160 lines
3.6 KiB
JavaScript
Raw Normal View History

2016-09-26 09:28:47 +00:00
/**
2016-09-24 14:32:31 +00:00
* Simulates a connection to a database by making asynchronous requests to a
* remote REST service that returns the results in JSON format.
* Using this class can perform any operation that can be done with a database,
* like open/close a connection or selecion/updating queries.
2016-09-24 14:32:31 +00:00
*
* Warning! You should set a well defined dababase level privileges to use this
* class or you could have a serious security hole in you application becasuse
* the user can send any statement to the server. For example: DROP DATABASE
2021-01-23 16:15:02 +00:00
*/
2020-05-03 20:35:24 +00:00
var Connection = new Class();
2016-09-26 09:28:47 +00:00
module.exports = Connection;
2022-05-30 01:30:33 +00:00
var Flag = {
2016-09-26 09:28:47 +00:00
NOT_NULL : 1
,PRI_KEY : 2
,AI : 512 | 2 | 1
};
2022-05-30 01:30:33 +00:00
var Type = {
2016-09-26 09:28:47 +00:00
BOOLEAN : 1
,INTEGER : 3
,DOUBLE : 4
,STRING : 5
,DATE : 8
,DATE_TIME : 9
};
2020-05-04 19:55:18 +00:00
Connection.extend({
2016-09-26 09:28:47 +00:00
Flag: Flag
,Type: Type
});
2020-05-04 19:55:18 +00:00
Connection.implement({
2016-09-23 22:47:34 +00:00
Extends: Vn.JsonConnection
/**
* Runs a SQL query on the database.
*
* @param {String} sql The SQL statement
* @param {Function} callback The function to call when operation is done
2021-01-23 16:15:02 +00:00
*/
2020-05-03 20:35:24 +00:00
,execSql: function(sql, callback) {
this.send('core/query', {'sql': sql},
this._onExec.bind(this, callback));
}
/**
* Runs a stmt on the database.
*
* @param {Sql.Stmt} stmt The statement
* @param {Function} callback The function to call when operation is done
2022-05-30 01:30:33 +00:00
* @param {Object} params The query params
2021-01-23 16:15:02 +00:00
*/
2022-05-30 01:30:33 +00:00
,execStmt: function(stmt, callback, params) {
this.execSql(stmt.render(params), callback);
}
/**
* Runs a query on the database.
*
* @param {String} query The SQL statement
* @param {Function} callback The function to call when operation is done
2022-05-30 01:30:33 +00:00
* @param {Object} params The query params
2021-01-23 16:15:02 +00:00
*/
2022-05-30 01:30:33 +00:00
,execQuery: function(query, callback, params) {
this.execStmt(new Sql.String({query: query}), callback, params);
}
/*
* Parses a value to date.
*/
2020-05-03 20:35:24 +00:00
,valueToDate: function(value) {
2020-05-04 19:55:18 +00:00
return fixTz(new Date(value));
}
/*
* Called when a query is executed.
*/
2020-05-03 20:35:24 +00:00
,_onExec: function(callback, json, error) {
2022-05-28 15:49:46 +00:00
const results = [];
if (json)
try {
if (json && json instanceof Array)
2022-05-28 15:49:46 +00:00
for (let i = 0; i < json.length; i++)
2020-05-03 20:35:24 +00:00
if (json[i] !== true) {
2022-05-28 15:49:46 +00:00
const rows = json[i].data;
const columns = json[i].columns;
const data = new Array(rows.length);
results.push({
data,
columns,
tables: json[i].tables
});
for (let j = 0; j < rows.length; j++) {
const row = data[j] = {};
for (let k = 0; k < columns.length; k++)
row[columns[k].name] = rows[j][k];
}
2022-05-28 15:49:46 +00:00
for (let j = 0; j < columns.length; j++) {
let castFunc = null;
const col = columns[j];
2022-05-28 15:49:46 +00:00
switch (col.type) {
2016-09-26 09:28:47 +00:00
case Type.DATE:
case Type.DATE_TIME:
case Type.TIMESTAMP:
castFunc = this.valueToDate;
break;
}
2020-05-03 20:35:24 +00:00
if (castFunc !== null) {
2022-05-28 15:49:46 +00:00
if (col.def != null)
col.def = castFunc(col.def);
2022-05-28 15:49:46 +00:00
for (let k = 0; k < data.length; k++)
if (data[k][col.name] != null)
data[k][col.name] = castFunc(data[k][col.name]);
}
}
2022-05-28 15:49:46 +00:00
} else
results.push(json[i]);
2020-05-03 20:35:24 +00:00
} catch (e) {
error = e;
}
if (callback)
2022-05-28 15:49:46 +00:00
callback(new Db.ResultSet(results, error));
}
});
2020-05-04 19:55:18 +00:00
// TODO: Read time zone from db configuration
var tz = {timeZone: 'Europe/Madrid'};
var isLocal = Intl
.DateTimeFormat()
.resolvedOptions()
.timeZone == tz.timeZone;
function fixTz(date) {
if (isLocal) return date;
var localDate = new Date(date.toLocaleString('en-US', tz));
var hasTime = localDate.getHours()
|| localDate.getMinutes()
|| localDate.getSeconds()
|| localDate.getMilliseconds();
if (!hasTime) {
date.setHours(date.getHours() + 12);
date.setHours(0, 0, 0, 0);
}
return date;
}