2016-01-26 18:38:21 +08:00
|
|
|
// TODO: use pgQueryRunner parameter directly
|
|
|
|
function OverviewsApi(queryTablesApi) {
|
|
|
|
this.pgQueryRunner = queryTablesApi.pgQueryRunner;
|
2016-01-20 02:31:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = OverviewsApi;
|
|
|
|
|
2016-01-26 18:38:21 +08:00
|
|
|
// TODO: share this with OverviewsApi? ... or maintain independence?
|
|
|
|
var affectedTableRegexCache = {
|
|
|
|
bbox: /!bbox!/g,
|
|
|
|
scale_denominator: /!scale_denominator!/g,
|
|
|
|
pixel_width: /!pixel_width!/g,
|
|
|
|
pixel_height: /!pixel_height!/g
|
|
|
|
};
|
2016-01-20 02:31:43 +08:00
|
|
|
|
2016-01-26 18:38:21 +08:00
|
|
|
function prepareSql(sql) {
|
|
|
|
return sql
|
|
|
|
.replace(affectedTableRegexCache.bbox, 'ST_MakeEnvelope(0,0,0,0)')
|
|
|
|
.replace(affectedTableRegexCache.scale_denominator, '0')
|
|
|
|
.replace(affectedTableRegexCache.pixel_width, '1')
|
|
|
|
.replace(affectedTableRegexCache.pixel_height, '1')
|
|
|
|
;
|
|
|
|
}
|
2016-01-20 02:31:43 +08:00
|
|
|
|
2016-01-26 18:38:21 +08:00
|
|
|
OverviewsApi.prototype.getOverviewsMetadata = function (username, sql, callback) {
|
|
|
|
var query = 'SELECT * FROM CDB_Overviews(CDB_QueryTablesText($windshaft$' + prepareSql(sql) + '$windshaft$))';
|
|
|
|
this.pgQueryRunner.run(username, query, function handleOverviewsRows(err, rows) {
|
|
|
|
if (err){
|
|
|
|
var msg = err.message ? err.message : err;
|
|
|
|
callback(new Error('could not get overviews metadata: ' + msg));
|
|
|
|
return;
|
2016-01-20 18:51:46 +08:00
|
|
|
}
|
2016-01-26 18:38:21 +08:00
|
|
|
var metadata = {};
|
|
|
|
rows.forEach(function(row) {
|
|
|
|
var table = row.base_table;
|
|
|
|
var table_metadata = metadata[table];
|
|
|
|
if ( !table_metadata ) {
|
|
|
|
table_metadata = metadata[table] = {};
|
|
|
|
}
|
|
|
|
table_metadata[row.z] = { table: row.overview_table };
|
|
|
|
});
|
|
|
|
return callback(null, metadata);
|
2016-01-20 02:31:43 +08:00
|
|
|
});
|
2016-01-26 18:38:21 +08:00
|
|
|
|
2016-01-20 02:31:43 +08:00
|
|
|
};
|