UNPKG

tedious

Version:

A TDS driver, for connecting to MS SQLServer databases.

135 lines (112 loc) 12.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _iconvLite = _interopRequireDefault(require("iconv-lite")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } const MAX = (1 << 16) - 1; const UNKNOWN_PLP_LEN = Buffer.from([0xfe, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff]); const PLP_TERMINATOR = Buffer.from([0x00, 0x00, 0x00, 0x00]); const NULL_LENGTH = Buffer.from([0xFF, 0xFF]); const MAX_NULL_LENGTH = Buffer.from([0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF]); const VarChar = { id: 0xA7, type: 'BIGVARCHR', name: 'VarChar', maximumLength: 8000, declaration: function (parameter) { const value = parameter.value; let length; if (parameter.length) { length = parameter.length; } else if (value != null) { length = value.length || 1; } else if (value === null && !parameter.output) { length = 1; } else { length = this.maximumLength; } if (length <= this.maximumLength) { return 'varchar(' + length + ')'; } else { return 'varchar(max)'; } }, resolveLength: function (parameter) { const value = parameter.value; if (parameter.length != null) { return parameter.length; } else if (value != null) { return value.length || 1; } else { return this.maximumLength; } }, generateTypeInfo(parameter) { const buffer = Buffer.alloc(8); buffer.writeUInt8(this.id, 0); if (parameter.length <= this.maximumLength) { buffer.writeUInt16LE(parameter.length, 1); } else { buffer.writeUInt16LE(MAX, 1); } if (parameter.collation) { parameter.collation.toBuffer().copy(buffer, 3, 0, 5); } return buffer; }, generateParameterLength(parameter, options) { const value = parameter.value; if (value == null) { if (parameter.length <= this.maximumLength) { return NULL_LENGTH; } else { return MAX_NULL_LENGTH; } } if (parameter.length <= this.maximumLength) { const buffer = Buffer.alloc(2); buffer.writeUInt16LE(value.length, 0); return buffer; } else { return UNKNOWN_PLP_LEN; } }, *generateParameterData(parameter, options) { const value = parameter.value; if (value == null) { return; } if (parameter.length <= this.maximumLength) { yield value; } else { if (value.length > 0) { const buffer = Buffer.alloc(4); buffer.writeUInt32LE(value.length, 0); yield buffer; yield value; } yield PLP_TERMINATOR; } }, validate: function (value, collation) { if (value == null) { return null; } if (typeof value !== 'string') { throw new TypeError('Invalid string.'); } if (!collation) { throw new Error('No collation was set by the server for the current connection.'); } if (!collation.codepage) { throw new Error('The collation set by the server has no associated encoding.'); } return _iconvLite.default.encode(value, collation.codepage); } }; var _default = VarChar; exports.default = _default; module.exports = VarChar; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["MAX","UNKNOWN_PLP_LEN","Buffer","from","PLP_TERMINATOR","NULL_LENGTH","MAX_NULL_LENGTH","VarChar","id","type","name","maximumLength","declaration","parameter","value","length","output","resolveLength","generateTypeInfo","buffer","alloc","writeUInt8","writeUInt16LE","collation","toBuffer","copy","generateParameterLength","options","generateParameterData","writeUInt32LE","validate","TypeError","Error","codepage","iconv","encode","module","exports"],"sources":["../../src/data-types/varchar.ts"],"sourcesContent":["import iconv from 'iconv-lite';\n\nimport { DataType } from '../data-type';\n\nconst MAX = (1 << 16) - 1;\nconst UNKNOWN_PLP_LEN = Buffer.from([0xfe, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff]);\nconst PLP_TERMINATOR = Buffer.from([0x00, 0x00, 0x00, 0x00]);\n\nconst NULL_LENGTH = Buffer.from([0xFF, 0xFF]);\nconst MAX_NULL_LENGTH = Buffer.from([0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF]);\n\nconst VarChar: { maximumLength: number } & DataType = {\n  id: 0xA7,\n  type: 'BIGVARCHR',\n  name: 'VarChar',\n  maximumLength: 8000,\n\n  declaration: function(parameter) {\n    const value = parameter.value as Buffer | null;\n\n    let length;\n    if (parameter.length) {\n      length = parameter.length;\n    } else if (value != null) {\n      length = value.length || 1;\n    } else if (value === null && !parameter.output) {\n      length = 1;\n    } else {\n      length = this.maximumLength;\n    }\n\n    if (length <= this.maximumLength) {\n      return 'varchar(' + length + ')';\n    } else {\n      return 'varchar(max)';\n    }\n  },\n\n  resolveLength: function(parameter) {\n    const value = parameter.value as Buffer | null;\n\n    if (parameter.length != null) {\n      return parameter.length;\n    } else if (value != null) {\n      return value.length || 1;\n    } else {\n      return this.maximumLength;\n    }\n  },\n\n  generateTypeInfo(parameter) {\n    const buffer = Buffer.alloc(8);\n    buffer.writeUInt8(this.id, 0);\n\n    if (parameter.length! <= this.maximumLength) {\n      buffer.writeUInt16LE(parameter.length!, 1);\n    } else {\n      buffer.writeUInt16LE(MAX, 1);\n    }\n\n    if (parameter.collation) {\n      parameter.collation.toBuffer().copy(buffer, 3, 0, 5);\n    }\n\n    return buffer;\n  },\n\n  generateParameterLength(parameter, options) {\n    const value = parameter.value as Buffer | null;\n\n    if (value == null) {\n      if (parameter.length! <= this.maximumLength) {\n        return NULL_LENGTH;\n      } else {\n        return MAX_NULL_LENGTH;\n      }\n    }\n\n    if (parameter.length! <= this.maximumLength) {\n      const buffer = Buffer.alloc(2);\n      buffer.writeUInt16LE(value.length, 0);\n      return buffer;\n    } else {\n      return UNKNOWN_PLP_LEN;\n    }\n  },\n\n  *generateParameterData(parameter, options) {\n    const value = parameter.value as Buffer | null;\n\n    if (value == null) {\n      return;\n    }\n\n    if (parameter.length! <= this.maximumLength) {\n      yield value;\n    } else {\n      if (value.length > 0) {\n        const buffer = Buffer.alloc(4);\n        buffer.writeUInt32LE(value.length, 0);\n        yield buffer;\n\n        yield value;\n      }\n\n      yield PLP_TERMINATOR;\n    }\n  },\n\n  validate: function(value, collation): Buffer | null {\n    if (value == null) {\n      return null;\n    }\n\n    if (typeof value !== 'string') {\n      throw new TypeError('Invalid string.');\n    }\n\n    if (!collation) {\n      throw new Error('No collation was set by the server for the current connection.');\n    }\n\n    if (!collation.codepage) {\n      throw new Error('The collation set by the server has no associated encoding.');\n    }\n\n    return iconv.encode(value, collation.codepage);\n  }\n};\n\nexport default VarChar;\nmodule.exports = VarChar;\n"],"mappings":"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"}