knex-firebird-dialect
Version:
Firebird dialect for Knex.js
167 lines (165 loc) • 22.7 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _readOnlyError2 = _interopRequireDefault(require("@babel/runtime/helpers/readOnlyError"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _get2 = _interopRequireDefault(require("@babel/runtime/helpers/get"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _querycompiler = _interopRequireDefault(require("knex/lib/query/querycompiler"));
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
function _superPropGet(t, o, e, r) { var p = (0, _get2["default"])((0, _getPrototypeOf2["default"])(1 & r ? t.prototype : t), o, e); return 2 & r && "function" == typeof p ? function (t) { return p.apply(e, t); } : p; } // Firebird Query Builder & Compiler
var identity = require("lodash/identity");
var reduce = require("lodash/reduce");
var QueryCompiler_Firebird = /*#__PURE__*/function (_QueryCompiler) {
function QueryCompiler_Firebird() {
(0, _classCallCheck2["default"])(this, QueryCompiler_Firebird);
return _callSuper(this, QueryCompiler_Firebird, arguments);
}
(0, _inherits2["default"])(QueryCompiler_Firebird, _QueryCompiler);
return (0, _createClass2["default"])(QueryCompiler_Firebird, [{
key: "columns",
value: function columns() {
var distinctClause = "";
if (this.onlyUnions()) {
return "";
}
var hints = this._hintComments();
var columns = this.grouped.columns || [];
var i = -1,
sql = [];
if (columns) {
while (++i < columns.length) {
var stmt = columns[i];
if (stmt.distinct) distinctClause = "distinct ";
if (stmt.distinctOn) {
distinctClause = this.distinctOn(stmt.value);
continue;
}
if (stmt.type === "aggregate") {
var _sql;
(_sql = sql).push.apply(_sql, (0, _toConsumableArray2["default"])(this.aggregate(stmt)));
} else if (stmt.type === "aggregateRaw") {
sql.push(this.aggregateRaw(stmt));
} else if (stmt.type === "analytic") {
sql.push(this.analytic(stmt));
} else if (stmt.value && stmt.value.length > 0) {
sql.push(this.formatter.columnize(stmt.value));
}
}
}
if (sql.length === 0) sql = ["*"];
return "select ".concat(this._limit(), " ").concat(this._offset(), " ").concat(hints).concat(distinctClause) + sql.join(", ") + (this.tableName ? " from ".concat(this.single.only ? "only " : "").concat(this.tableName) : "");
}
}, {
key: "_limit",
value: function _limit() {
return _superPropGet(QueryCompiler_Firebird, "limit", this, 3)([]).replace("limit", "first");
}
}, {
key: "_offset",
value: function _offset() {
return _superPropGet(QueryCompiler_Firebird, "offset", this, 3)([]).replace("offset", "skip");
}
}, {
key: "offset",
value: function offset() {
return "";
}
}, {
key: "limit",
value: function limit() {
return "";
}
}, {
key: "truncate",
value: function truncate() {
throw new Error("Truncate SQL command does not exists in Firebird.");
}
}, {
key: "insert",
value: function insert() {
var sql = _superPropGet(QueryCompiler_Firebird, "insert", this, 3)([]);
if (sql === "") return sql;
var returning = this.single.returning;
if (returning) sql += this._returning(returning);
return {
sql: sql,
returning: returning
};
}
}, {
key: "_returning",
value: function _returning(value) {
return value ? " returning ".concat(this.formatter.columnize(value)) : "";
}
}, {
key: "_prepInsert",
value: function _prepInsert(insertValues) {
if (Array.isArray(insertValues)) {
if (insertValues.length !== 1) {
throw new Error("Firebird does not support multiple insertions.");
}
insertValues = insertValues[0];
}
var newValue = {};
for (var key in insertValues) {
if (Object.prototype.hasOwnProperty.call(insertValues, key)) {
var value = insertValues[key];
if (typeof value !== "undefined") {
newValue[key] = value;
}
}
}
return _superPropGet(QueryCompiler_Firebird, "_prepInsert", this, 3)([newValue]);
}
}, {
key: "columnInfo",
value: function columnInfo() {
var column = this.getColumnName(this.single.columnInfo);
// The user may have specified a custom wrapIdentifier function in the config. We
// need to run the identifiers through that function, but not format them as
// identifiers otherwise.
var table = this.client.customWrapIdentifier(this.single.table, identity);
var self = this;
return {
sql: "\n select \n rlf.rdb$field_name as name,\n fld.rdb$character_length as max_length,\n typ.rdb$type_name as type,\n rlf.rdb$null_flag as not_null\n from rdb$relation_fields rlf\n inner join rdb$fields fld on fld.rdb$field_name = rlf.rdb$field_source\n inner join rdb$types typ on typ.rdb$type = fld.rdb$field_type\n where rdb$relation_name = '".concat(table.toUpperCase(), "'\n "),
output: function output(_ref) {
var rows = _ref.rows;
var result = reduce(rows, function (columns, value) {
var name = self.getColumnName(value[self.getColumnName("name")].trim());
columns[name] = {
type: value[self.getColumnName("type")].trim().toLowerCase(),
nullable: !value[self.getColumnName("not_null")]
};
if (value.MAX_LENGTH) {
columns[name] = value.MAX_LENGTH;
}
return columns;
}, {});
if (column && !result[column]) {
throw new Error("Specified column \"".concat(column, "\" was not found!"));
}
return column ? result[column] : result;
}
};
}
}, {
key: "getColumnName",
value: function getColumnName(name) {
if (!name) {
return name;
}
return this.client.config.connection.lowercase_keys ? name.toLowerCase() : name;
}
}]);
}(_querycompiler["default"]);
var _default = exports["default"] = QueryCompiler_Firebird;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_querycompiler","_interopRequireDefault","require","_callSuper","t","o","e","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","apply","Boolean","prototype","valueOf","call","_superPropGet","r","p","_get2","identity","reduce","QueryCompiler_Firebird","_QueryCompiler","_classCallCheck2","arguments","_inherits2","_createClass2","key","value","columns","distinctClause","onlyUnions","hints","_hintComments","grouped","i","sql","length","stmt","distinct","distinctOn","type","_sql","push","_toConsumableArray2","aggregate","aggregateRaw","analytic","formatter","columnize","concat","_limit","_offset","join","tableName","single","only","replace","offset","limit","truncate","Error","insert","returning","_returning","_prepInsert","insertValues","Array","isArray","newValue","Object","hasOwnProperty","columnInfo","column","getColumnName","table","client","customWrapIdentifier","self","toUpperCase","output","_ref","rows","result","name","trim","toLowerCase","nullable","MAX_LENGTH","config","connection","lowercase_keys","QueryCompiler","_default","exports"],"sources":["../../src/query/compiler.js"],"sourcesContent":["// Firebird Query Builder & Compiler\nimport QueryCompiler from \"knex/lib/query/querycompiler\";\nconst identity = require(\"lodash/identity\");\nconst reduce = require(\"lodash/reduce\");\n\nclass QueryCompiler_Firebird extends QueryCompiler {\n  columns() {\n    let distinctClause = \"\";\n    if (this.onlyUnions()) {\n      return \"\";\n    }\n\n    const hints = this._hintComments();\n    const columns = this.grouped.columns || [];\n    let i = -1,\n      sql = [];\n\n    if (columns) {\n      while (++i < columns.length) {\n        const stmt = columns[i];\n        if (stmt.distinct) distinctClause = \"distinct \";\n        if (stmt.distinctOn) {\n          distinctClause = this.distinctOn(stmt.value);\n          continue;\n        }\n        if (stmt.type === \"aggregate\") {\n          sql.push(...this.aggregate(stmt));\n        } else if (stmt.type === \"aggregateRaw\") {\n          sql.push(this.aggregateRaw(stmt));\n        } else if (stmt.type === \"analytic\") {\n          sql.push(this.analytic(stmt));\n        } else if (stmt.value && stmt.value.length > 0) {\n          sql.push(this.formatter.columnize(stmt.value));\n        }\n      }\n    }\n    if (sql.length === 0) sql = [\"*\"];\n    return (\n      `select ${this._limit()} ${this._offset()} ${hints}${distinctClause}` +\n      sql.join(\", \") +\n      (this.tableName\n        ? ` from ${this.single.only ? \"only \" : \"\"}${this.tableName}`\n        : \"\")\n    );\n  }\n\n  _limit() {\n    return super.limit().replace(\"limit\", \"first\");\n  }\n\n  _offset() {\n    return super.offset().replace(\"offset\", \"skip\");\n  }\n\n  offset() {\n    return \"\";\n  }\n\n  limit() {\n    return \"\";\n  }\n\n  truncate() {\n    throw new Error(\"Truncate SQL command does not exists in Firebird.\");\n  }\n\n  insert() {\n    let sql = super.insert();\n    if (sql === \"\") return sql;\n\n    const { returning } = this.single;\n    if (returning) sql += this._returning(returning);\n\n    return {\n      sql: sql,\n      returning,\n    };\n  }\n\n  _returning(value) {\n    return value ? ` returning ${this.formatter.columnize(value)}` : \"\";\n  }\n\n  _prepInsert(insertValues) {\n    if (Array.isArray(insertValues)) {\n      if (insertValues.length !== 1) {\n        throw new Error(\"Firebird does not support multiple insertions.\");\n      }\n      insertValues = insertValues[0];\n    }\n\n    const newValue = {};\n    for (const key in insertValues) {\n      if (Object.prototype.hasOwnProperty.call(insertValues, key)) {\n        const value = insertValues[key];\n        if (typeof value !== \"undefined\") {\n          newValue[key] = value;\n        }\n      }\n    }\n    return super._prepInsert(newValue);\n  }\n\n  columnInfo() {\n    const column = this.getColumnName(this.single.columnInfo);\n\n    // The user may have specified a custom wrapIdentifier function in the config. We\n    // need to run the identifiers through that function, but not format them as\n    // identifiers otherwise.\n    const table = this.client.customWrapIdentifier(this.single.table, identity);\n\n    const self = this;\n    return {\n      sql: `\n      select \n        rlf.rdb$field_name as name,\n        fld.rdb$character_length as max_length,\n        typ.rdb$type_name as type,\n        rlf.rdb$null_flag as not_null\n      from rdb$relation_fields rlf\n      inner join rdb$fields fld on fld.rdb$field_name = rlf.rdb$field_source\n      inner join rdb$types typ on typ.rdb$type = fld.rdb$field_type\n      where rdb$relation_name = '${table.toUpperCase()}'\n      `,\n      output({ rows }) {\n        const result = reduce(\n          rows,\n          function (columns, value) {\n            const name = self.getColumnName(\n              value[self.getColumnName(\"name\")].trim()\n            );\n\n            columns[name] = {\n              type: value[self.getColumnName(\"type\")].trim().toLowerCase(),\n              nullable: !value[self.getColumnName(\"not_null\")],\n            };\n\n            if (value.MAX_LENGTH) {\n              columns[name] = value.MAX_LENGTH;\n            }\n\n            return columns;\n          },\n          {}\n        );\n\n        if (column && !result[column]) {\n          throw new Error(`Specified column \"${column}\" was not found!`);\n        }\n        return column ? result[column] : result;\n      },\n    };\n  }\n\n  getColumnName(name) {\n    if (!name) {\n      return name;\n    }\n    return this.client.config.connection.lowercase_keys\n      ? name.toLowerCase()\n      : name;\n  }\n}\n\nexport default QueryCompiler_Firebird;\n"],"mappings":"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","ignoreList":[]}