CartoDB-SQL-API/app/models/formats/pg/arraybuffer.js

90 lines
2.2 KiB
JavaScript
Raw Normal View History

2018-10-24 21:42:33 +08:00
'use strict';
2015-05-13 19:00:01 +08:00
var _ = require('underscore');
2019-01-16 22:58:11 +08:00
var Pg = require('./../pg');
var ArrayBufferSer = require("../../bin_encoder");
2013-05-17 17:44:50 +08:00
2014-08-03 02:27:05 +08:00
function BinaryFormat() {}
2013-05-17 17:44:50 +08:00
2019-01-16 22:58:11 +08:00
BinaryFormat.prototype = new Pg('arraybuffer');
2013-05-17 17:44:50 +08:00
2014-08-03 02:27:05 +08:00
BinaryFormat.prototype._contentType = "application/octet-stream";
2013-05-17 17:44:50 +08:00
2014-08-03 02:27:05 +08:00
BinaryFormat.prototype._extractTypeFromName = function(name) {
2015-05-13 19:00:01 +08:00
var g = name.match(/.*__(uintclamp|uint|int|float)(8|16|32)/i);
if(g && g.length === 3) {
2013-05-17 17:44:50 +08:00
var typeName = g[1] + g[2];
return ArrayBufferSer.typeNames[typeName];
}
};
2015-05-13 19:00:01 +08:00
// jshint maxcomplexity:12
2014-08-03 02:27:05 +08:00
BinaryFormat.prototype.transform = function(result, options, callback) {
2013-05-17 17:44:50 +08:00
var total_rows = result.rowCount;
2014-08-03 02:23:47 +08:00
var rows = result.rows;
2013-05-17 17:44:50 +08:00
2018-10-24 21:42:33 +08:00
// get headers
2013-05-17 17:44:50 +08:00
if(!total_rows) {
callback(null, new Buffer(0));
return;
}
var headersNames = Object.keys(rows[0]);
var headerTypes = [];
if(_.contains(headersNames, 'the_geom')) {
callback(new Error("geometry types are not supported"), null);
return;
}
try {
2015-05-13 19:00:01 +08:00
var i;
2019-01-16 22:58:11 +08:00
var r;
var n;
2015-05-13 19:00:01 +08:00
var t;
2013-05-17 17:44:50 +08:00
// get header types (and guess from name)
2015-05-13 19:00:01 +08:00
for(i = 0; i < headersNames.length; ++i) {
r = rows[0];
n = headersNames[i];
if(typeof(r[n]) === 'string') {
2013-05-17 17:44:50 +08:00
headerTypes.push(ArrayBufferSer.STRING);
2015-05-13 19:00:01 +08:00
} else if(typeof(r[n]) === 'object') {
t = this._extractTypeFromName(n);
t = t || ArrayBufferSer.FLOAT32;
2013-05-17 17:44:50 +08:00
headerTypes.push(ArrayBufferSer.BUFFER + t);
} else {
2015-05-13 19:00:01 +08:00
t = this._extractTypeFromName(n);
headerTypes.push(t || ArrayBufferSer.FLOAT32);
2013-05-17 17:44:50 +08:00
}
}
// pack the data
var header = new ArrayBufferSer(ArrayBufferSer.STRING, headersNames);
var data = [header];
2015-05-13 19:00:01 +08:00
for(i = 0; i < headersNames.length; ++i) {
2013-05-17 17:44:50 +08:00
var d = [];
2019-01-16 22:58:11 +08:00
n = headersNames[i];
for(r = 0; r < total_rows; ++r) {
2018-10-24 21:42:33 +08:00
var row = rows[r][n];
2013-05-17 17:44:50 +08:00
if(headerTypes[i] > ArrayBufferSer.BUFFER) {
row = new ArrayBufferSer(headerTypes[i] - ArrayBufferSer.BUFFER, row);
}
d.push(row);
2014-08-03 02:23:47 +08:00
}
2013-05-17 17:44:50 +08:00
var b = new ArrayBufferSer(headerTypes[i], d);
data.push(b);
}
// create the final buffer
var all = new ArrayBufferSer(ArrayBufferSer.BUFFER, data);
callback(null, all.buffer);
} catch(e) {
callback(e, null);
}
};
2014-08-03 02:27:05 +08:00
module.exports = BinaryFormat;