UNPKG

knex-firebird-dialect

Version:
106 lines (103 loc) 17.9 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; 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 _compiler = _interopRequireDefault(require("knex/lib/schema/compiler")); function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } 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: Column Builder & Compiler // ------- // Schema Compiler // ------- var SchemaCompiler_Firebird = /*#__PURE__*/function (_SchemaCompiler) { function SchemaCompiler_Firebird() { (0, _classCallCheck2["default"])(this, SchemaCompiler_Firebird); return _callSuper(this, SchemaCompiler_Firebird, arguments); } (0, _inherits2["default"])(SchemaCompiler_Firebird, _SchemaCompiler); return (0, _createClass2["default"])(SchemaCompiler_Firebird, [{ key: "hasTable", value: function hasTable(tableName) { var fullTableName = this.formatter.wrap(prefixedTableName(this.schema, String(tableName))).toUpperCase(); var sql = "select 1 from rdb$relations where rdb$relation_name = '".concat(fullTableName, "'"); this.pushQuery({ sql: sql, output: function output(_ref) { var rows = _ref.rows, fields = _ref.fields; if (!rows || rows.length === 0) { return false; } var key = fields[0]; return Number(rows[0][key]) === 1; } }); } // Compile the query to determine if a column exists. }, { key: "hasColumn", value: function hasColumn(tableName, column) { this.pushQuery({ sql: "select i.rdb$field_name as \"field\" from " + "rdb$relations r join rdb$RELATION_FIELDS i " + "on (i.rdb$relation_name = r.rdb$relation_name) " + "where r.rdb$relation_name = '".concat(this.formatter.wrap(tableName.toUpperCase()), "'"), output: function output(_ref2) { var rows = _ref2.rows, fields = _ref2.fields; var key = fields[0].trim(); var target = column.trim().toLowerCase(); var _iterator = _createForOfIteratorHelper(rows), _step; try { for (_iterator.s(); !(_step = _iterator.n()).done;) { var row = _step.value; if (row[key].trim().toLowerCase() === target) { return true; } } } catch (err) { _iterator.e(err); } finally { _iterator.f(); } return false; } }); } }, { key: "getColumnName", value: function getColumnName() { var name = _superPropGet(SchemaCompiler_Firebird, "getColumnName", this, 3)([arguments]); return this.client.config.connection.lowercase_keys ? name.toLowerCase() : name; } }, { key: "dropTableIfExists", value: function dropTableIfExists(tableName) { var fullTableName = this.formatter.wrap(prefixedTableName(this.schema, tableName)).toUpperCase(); var dropTableSql = this.dropTablePrefix + fullTableName; this.pushQuery("\n EXECUTE BLOCK AS BEGIN\n if (exists(select 1 from rdb$relations where rdb$relation_name = '".concat(fullTableName, "')) then\n execute statement '").concat(dropTableSql, "';\n END\n ")); return this; } // eslint-disable-next-line no-unused-vars }, { key: "renameTable", value: function renameTable(tableName, to) { throw new Error("".concat(this.name, " is not implemented for this dialect (http://www.firebirdfaq.org/faq363/).")); } }]); }(_compiler["default"]); function prefixedTableName(prefix, table) { return prefix ? "".concat(prefix, ".").concat(table) : table; } SchemaCompiler_Firebird.prototype.lowerCase = true; var _default = exports["default"] = SchemaCompiler_Firebird; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_compiler","_interopRequireDefault","require","_createForOfIteratorHelper","r","e","t","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","_n","F","s","n","done","value","f","TypeError","o","a","u","call","next","_arrayLikeToArray","toString","slice","constructor","name","from","test","_callSuper","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","apply","Boolean","prototype","valueOf","_superPropGet","p","_get2","SchemaCompiler_Firebird","_SchemaCompiler","_classCallCheck2","arguments","_inherits2","_createClass2","key","hasTable","tableName","fullTableName","formatter","wrap","prefixedTableName","schema","String","toUpperCase","sql","concat","pushQuery","output","_ref","rows","fields","Number","hasColumn","column","_ref2","trim","target","toLowerCase","_iterator","_step","row","err","getColumnName","client","config","connection","lowercase_keys","dropTableIfExists","dropTableSql","dropTablePrefix","renameTable","to","Error","SchemaCompiler","prefix","table","lowerCase","_default","exports"],"sources":["../../src/schema/compiler.js"],"sourcesContent":["// Firebird: Column Builder & Compiler\n// -------\nimport SchemaCompiler from \"knex/lib/schema/compiler\";\n\n// Schema Compiler\n// -------\nclass SchemaCompiler_Firebird extends SchemaCompiler {\n  hasTable(tableName) {\n    const fullTableName = this.formatter\n      .wrap(prefixedTableName(this.schema, String(tableName)))\n      .toUpperCase();\n\n    const sql = `select 1 from rdb$relations where rdb$relation_name = '${fullTableName}'`;\n    this.pushQuery({\n      sql,\n      output: ({ rows, fields }) => {\n        if (!rows || rows.length === 0) {\n          return false;\n        }\n        const key = fields[0];\n        return Number(rows[0][key]) === 1;\n      },\n    });\n  }\n\n  // Compile the query to determine if a column exists.\n  hasColumn(tableName, column) {\n    this.pushQuery({\n      sql:\n        `select i.rdb$field_name as \"field\" from ` +\n        `rdb$relations r join rdb$RELATION_FIELDS i ` +\n        `on (i.rdb$relation_name = r.rdb$relation_name) ` +\n        `where r.rdb$relation_name = '${this.formatter.wrap(\n          tableName.toUpperCase()\n        )}'`,\n      output({ rows, fields }) {\n        const key = fields[0].trim();\n        const target = column.trim().toLowerCase();\n        for (const row of rows) {\n          if (row[key].trim().toLowerCase() === target) {\n            return true;\n          }\n        }\n        return false;\n      },\n    });\n  }\n\n  getColumnName() {\n    const name = super.getColumnName(arguments);\n    return this.client.config.connection.lowercase_keys\n      ? name.toLowerCase()\n      : name;\n  }\n\n  dropTableIfExists(tableName) {\n    const fullTableName = this.formatter\n      .wrap(prefixedTableName(this.schema, tableName))\n      .toUpperCase();\n    const dropTableSql = this.dropTablePrefix + fullTableName;\n\n    this.pushQuery(`\n      EXECUTE BLOCK AS BEGIN\n      if (exists(select 1 from rdb$relations where rdb$relation_name = '${fullTableName}')) then\n      execute statement '${dropTableSql}';\n      END\n    `);\n\n    return this;\n  }\n\n  // eslint-disable-next-line no-unused-vars\n  renameTable(tableName, to) {\n    throw new Error(\n      `${this.name} is not implemented for this dialect (http://www.firebirdfaq.org/faq363/).`\n    );\n  }\n}\n\nfunction prefixedTableName(prefix, table) {\n  return prefix ? `${prefix}.${table}` : table;\n}\n\nSchemaCompiler_Firebird.prototype.lowerCase = true;\n\nexport default SchemaCompiler_Firebird;\n"],"mappings":"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","ignoreList":[]}