tedious
Version:
A TDS driver, for connecting to MS SQLServer databases.
126 lines (100 loc) • 13.1 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _writableTrackingBuffer = _interopRequireDefault(require("../tracking-buffer/writable-tracking-buffer"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
const TVP_ROW_TOKEN = Buffer.from([0x01]);
const TVP_END_TOKEN = Buffer.from([0x00]);
const NULL_LENGTH = Buffer.from([0xFF, 0xFF]);
const TVP = {
id: 0xF3,
type: 'TVPTYPE',
name: 'TVP',
declaration: function (parameter) {
const value = parameter.value; // Temporary solution. Remove 'any' later.
return value.name + ' readonly';
},
generateTypeInfo(parameter) {
var _parameter$value, _parameter$value2;
const databaseName = '';
const schema = ((_parameter$value = parameter.value) === null || _parameter$value === void 0 ? void 0 : _parameter$value.schema) ?? '';
const typeName = ((_parameter$value2 = parameter.value) === null || _parameter$value2 === void 0 ? void 0 : _parameter$value2.name) ?? '';
const bufferLength = 1 + 1 + Buffer.byteLength(databaseName, 'ucs2') + 1 + Buffer.byteLength(schema, 'ucs2') + 1 + Buffer.byteLength(typeName, 'ucs2');
const buffer = new _writableTrackingBuffer.default(bufferLength, 'ucs2');
buffer.writeUInt8(this.id);
buffer.writeBVarchar(databaseName);
buffer.writeBVarchar(schema);
buffer.writeBVarchar(typeName);
return buffer.data;
},
generateParameterLength(parameter, options) {
if (parameter.value == null) {
return NULL_LENGTH;
}
const {
columns
} = parameter.value;
const buffer = Buffer.alloc(2);
buffer.writeUInt16LE(columns.length, 0);
return buffer;
},
*generateParameterData(parameter, options) {
if (parameter.value == null) {
yield TVP_END_TOKEN;
yield TVP_END_TOKEN;
return;
}
const {
columns,
rows
} = parameter.value;
for (let i = 0, len = columns.length; i < len; i++) {
const column = columns[i];
const buff = Buffer.alloc(6); // UserType
buff.writeUInt32LE(0x00000000, 0); // Flags
buff.writeUInt16LE(0x0000, 4);
yield buff; // TYPE_INFO
yield column.type.generateTypeInfo(column); // ColName
yield Buffer.from([0x00]);
}
yield TVP_END_TOKEN;
for (let i = 0, length = rows.length; i < length; i++) {
yield TVP_ROW_TOKEN;
const row = rows[i];
for (let k = 0, len2 = row.length; k < len2; k++) {
const column = columns[k];
const value = row[k];
const param = {
value: column.type.validate(value, parameter.collation),
length: column.length,
scale: column.scale,
precision: column.precision
}; // TvpColumnData
yield column.type.generateParameterLength(param, options);
yield* column.type.generateParameterData(param, options);
}
}
yield TVP_END_TOKEN;
},
validate: function (value) {
if (value == null) {
return null;
}
if (typeof value !== 'object') {
throw new TypeError('Invalid table.');
}
if (!Array.isArray(value.columns)) {
throw new TypeError('Invalid table.');
}
if (!Array.isArray(value.rows)) {
throw new TypeError('Invalid table.');
}
return value;
}
};
var _default = TVP;
exports.default = _default;
module.exports = TVP;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["TVP_ROW_TOKEN","Buffer","from","TVP_END_TOKEN","NULL_LENGTH","TVP","id","type","name","declaration","parameter","value","generateTypeInfo","databaseName","schema","typeName","bufferLength","byteLength","buffer","WritableTrackingBuffer","writeUInt8","writeBVarchar","data","generateParameterLength","options","columns","alloc","writeUInt16LE","length","generateParameterData","rows","i","len","column","buff","writeUInt32LE","row","k","len2","param","validate","collation","scale","precision","TypeError","Array","isArray","module","exports"],"sources":["../../src/data-types/tvp.ts"],"sourcesContent":["import { DataType } from '../data-type';\nimport WritableTrackingBuffer from '../tracking-buffer/writable-tracking-buffer';\n\nconst TVP_ROW_TOKEN = Buffer.from([0x01]);\nconst TVP_END_TOKEN = Buffer.from([0x00]);\n\nconst NULL_LENGTH = Buffer.from([0xFF, 0xFF]);\n\nconst TVP: DataType = {\n  id: 0xF3,\n  type: 'TVPTYPE',\n  name: 'TVP',\n\n  declaration: function(parameter) {\n    const value = parameter.value as any; // Temporary solution. Remove 'any' later.\n    return value.name + ' readonly';\n  },\n\n  generateTypeInfo(parameter) {\n    const databaseName = '';\n    const schema = parameter.value?.schema ?? '';\n    const typeName = parameter.value?.name ?? '';\n\n    const bufferLength = 1 +\n      1 + Buffer.byteLength(databaseName, 'ucs2') +\n      1 + Buffer.byteLength(schema, 'ucs2') +\n      1 + Buffer.byteLength(typeName, 'ucs2');\n\n    const buffer = new WritableTrackingBuffer(bufferLength, 'ucs2');\n    buffer.writeUInt8(this.id);\n    buffer.writeBVarchar(databaseName);\n    buffer.writeBVarchar(schema);\n    buffer.writeBVarchar(typeName);\n\n    return buffer.data;\n  },\n\n  generateParameterLength(parameter, options) {\n    if (parameter.value == null) {\n      return NULL_LENGTH;\n    }\n\n    const { columns } = parameter.value;\n    const buffer = Buffer.alloc(2);\n    buffer.writeUInt16LE(columns.length, 0);\n    return buffer;\n  },\n\n  *generateParameterData(parameter, options) {\n    if (parameter.value == null) {\n      yield TVP_END_TOKEN;\n      yield TVP_END_TOKEN;\n      return;\n    }\n\n    const { columns, rows } = parameter.value;\n\n    for (let i = 0, len = columns.length; i < len; i++) {\n      const column = columns[i];\n\n      const buff = Buffer.alloc(6);\n      // UserType\n      buff.writeUInt32LE(0x00000000, 0);\n\n      // Flags\n      buff.writeUInt16LE(0x0000, 4);\n      yield buff;\n\n      // TYPE_INFO\n      yield column.type.generateTypeInfo(column);\n\n      // ColName\n      yield Buffer.from([0x00]);\n    }\n\n    yield TVP_END_TOKEN;\n\n    for (let i = 0, length = rows.length; i < length; i++) {\n      yield TVP_ROW_TOKEN;\n\n      const row = rows[i];\n      for (let k = 0, len2 = row.length; k < len2; k++) {\n        const column = columns[k];\n        const value = row[k];\n\n        const param = {\n          value: column.type.validate(value, parameter.collation),\n          length: column.length,\n          scale: column.scale,\n          precision: column.precision\n        };\n\n        // TvpColumnData\n        yield column.type.generateParameterLength(param, options);\n        yield * column.type.generateParameterData(param, options);\n      }\n    }\n\n    yield TVP_END_TOKEN;\n  },\n\n  validate: function(value): Buffer | null {\n    if (value == null) {\n      return null;\n    }\n\n    if (typeof value !== 'object') {\n      throw new TypeError('Invalid table.');\n    }\n\n    if (!Array.isArray(value.columns)) {\n      throw new TypeError('Invalid table.');\n    }\n\n    if (!Array.isArray(value.rows)) {\n      throw new TypeError('Invalid table.');\n    }\n\n    return value;\n  }\n};\n\nexport default TVP;\nmodule.exports = TVP;\n"],"mappings":";;;;;;;AACA;;;;AAEA,MAAMA,aAAa,GAAGC,MAAM,CAACC,IAAP,CAAY,CAAC,IAAD,CAAZ,CAAtB;AACA,MAAMC,aAAa,GAAGF,MAAM,CAACC,IAAP,CAAY,CAAC,IAAD,CAAZ,CAAtB;AAEA,MAAME,WAAW,GAAGH,MAAM,CAACC,IAAP,CAAY,CAAC,IAAD,EAAO,IAAP,CAAZ,CAApB;AAEA,MAAMG,GAAa,GAAG;EACpBC,EAAE,EAAE,IADgB;EAEpBC,IAAI,EAAE,SAFc;EAGpBC,IAAI,EAAE,KAHc;EAKpBC,WAAW,EAAE,UAASC,SAAT,EAAoB;IAC/B,MAAMC,KAAK,GAAGD,SAAS,CAACC,KAAxB,CAD+B,CACO;;IACtC,OAAOA,KAAK,CAACH,IAAN,GAAa,WAApB;EACD,CARmB;;EAUpBI,gBAAgB,CAACF,SAAD,EAAY;IAAA;;IAC1B,MAAMG,YAAY,GAAG,EAArB;IACA,MAAMC,MAAM,GAAG,qBAAAJ,SAAS,CAACC,KAAV,sEAAiBG,MAAjB,KAA2B,EAA1C;IACA,MAAMC,QAAQ,GAAG,sBAAAL,SAAS,CAACC,KAAV,wEAAiBH,IAAjB,KAAyB,EAA1C;IAEA,MAAMQ,YAAY,GAAG,IACnB,CADmB,GACff,MAAM,CAACgB,UAAP,CAAkBJ,YAAlB,EAAgC,MAAhC,CADe,GAEnB,CAFmB,GAEfZ,MAAM,CAACgB,UAAP,CAAkBH,MAAlB,EAA0B,MAA1B,CAFe,GAGnB,CAHmB,GAGfb,MAAM,CAACgB,UAAP,CAAkBF,QAAlB,EAA4B,MAA5B,CAHN;IAKA,MAAMG,MAAM,GAAG,IAAIC,+BAAJ,CAA2BH,YAA3B,EAAyC,MAAzC,CAAf;IACAE,MAAM,CAACE,UAAP,CAAkB,KAAKd,EAAvB;IACAY,MAAM,CAACG,aAAP,CAAqBR,YAArB;IACAK,MAAM,CAACG,aAAP,CAAqBP,MAArB;IACAI,MAAM,CAACG,aAAP,CAAqBN,QAArB;IAEA,OAAOG,MAAM,CAACI,IAAd;EACD,CA3BmB;;EA6BpBC,uBAAuB,CAACb,SAAD,EAAYc,OAAZ,EAAqB;IAC1C,IAAId,SAAS,CAACC,KAAV,IAAmB,IAAvB,EAA6B;MAC3B,OAAOP,WAAP;IACD;;IAED,MAAM;MAAEqB;IAAF,IAAcf,SAAS,CAACC,KAA9B;IACA,MAAMO,MAAM,GAAGjB,MAAM,CAACyB,KAAP,CAAa,CAAb,CAAf;IACAR,MAAM,CAACS,aAAP,CAAqBF,OAAO,CAACG,MAA7B,EAAqC,CAArC;IACA,OAAOV,MAAP;EACD,CAtCmB;;EAwCpB,CAACW,qBAAD,CAAuBnB,SAAvB,EAAkCc,OAAlC,EAA2C;IACzC,IAAId,SAAS,CAACC,KAAV,IAAmB,IAAvB,EAA6B;MAC3B,MAAMR,aAAN;MACA,MAAMA,aAAN;MACA;IACD;;IAED,MAAM;MAAEsB,OAAF;MAAWK;IAAX,IAAoBpB,SAAS,CAACC,KAApC;;IAEA,KAAK,IAAIoB,CAAC,GAAG,CAAR,EAAWC,GAAG,GAAGP,OAAO,CAACG,MAA9B,EAAsCG,CAAC,GAAGC,GAA1C,EAA+CD,CAAC,EAAhD,EAAoD;MAClD,MAAME,MAAM,GAAGR,OAAO,CAACM,CAAD,CAAtB;MAEA,MAAMG,IAAI,GAAGjC,MAAM,CAACyB,KAAP,CAAa,CAAb,CAAb,CAHkD,CAIlD;;MACAQ,IAAI,CAACC,aAAL,CAAmB,UAAnB,EAA+B,CAA/B,EALkD,CAOlD;;MACAD,IAAI,CAACP,aAAL,CAAmB,MAAnB,EAA2B,CAA3B;MACA,MAAMO,IAAN,CATkD,CAWlD;;MACA,MAAMD,MAAM,CAAC1B,IAAP,CAAYK,gBAAZ,CAA6BqB,MAA7B,CAAN,CAZkD,CAclD;;MACA,MAAMhC,MAAM,CAACC,IAAP,CAAY,CAAC,IAAD,CAAZ,CAAN;IACD;;IAED,MAAMC,aAAN;;IAEA,KAAK,IAAI4B,CAAC,GAAG,CAAR,EAAWH,MAAM,GAAGE,IAAI,CAACF,MAA9B,EAAsCG,CAAC,GAAGH,MAA1C,EAAkDG,CAAC,EAAnD,EAAuD;MACrD,MAAM/B,aAAN;MAEA,MAAMoC,GAAG,GAAGN,IAAI,CAACC,CAAD,CAAhB;;MACA,KAAK,IAAIM,CAAC,GAAG,CAAR,EAAWC,IAAI,GAAGF,GAAG,CAACR,MAA3B,EAAmCS,CAAC,GAAGC,IAAvC,EAA6CD,CAAC,EAA9C,EAAkD;QAChD,MAAMJ,MAAM,GAAGR,OAAO,CAACY,CAAD,CAAtB;QACA,MAAM1B,KAAK,GAAGyB,GAAG,CAACC,CAAD,CAAjB;QAEA,MAAME,KAAK,GAAG;UACZ5B,KAAK,EAAEsB,MAAM,CAAC1B,IAAP,CAAYiC,QAAZ,CAAqB7B,KAArB,EAA4BD,SAAS,CAAC+B,SAAtC,CADK;UAEZb,MAAM,EAAEK,MAAM,CAACL,MAFH;UAGZc,KAAK,EAAET,MAAM,CAACS,KAHF;UAIZC,SAAS,EAAEV,MAAM,CAACU;QAJN,CAAd,CAJgD,CAWhD;;QACA,MAAMV,MAAM,CAAC1B,IAAP,CAAYgB,uBAAZ,CAAoCgB,KAApC,EAA2Cf,OAA3C,CAAN;QACA,OAAQS,MAAM,CAAC1B,IAAP,CAAYsB,qBAAZ,CAAkCU,KAAlC,EAAyCf,OAAzC,CAAR;MACD;IACF;;IAED,MAAMrB,aAAN;EACD,CA3FmB;;EA6FpBqC,QAAQ,EAAE,UAAS7B,KAAT,EAA+B;IACvC,IAAIA,KAAK,IAAI,IAAb,EAAmB;MACjB,OAAO,IAAP;IACD;;IAED,IAAI,OAAOA,KAAP,KAAiB,QAArB,EAA+B;MAC7B,MAAM,IAAIiC,SAAJ,CAAc,gBAAd,CAAN;IACD;;IAED,IAAI,CAACC,KAAK,CAACC,OAAN,CAAcnC,KAAK,CAACc,OAApB,CAAL,EAAmC;MACjC,MAAM,IAAImB,SAAJ,CAAc,gBAAd,CAAN;IACD;;IAED,IAAI,CAACC,KAAK,CAACC,OAAN,CAAcnC,KAAK,CAACmB,IAApB,CAAL,EAAgC;MAC9B,MAAM,IAAIc,SAAJ,CAAc,gBAAd,CAAN;IACD;;IAED,OAAOjC,KAAP;EACD;AA/GmB,CAAtB;eAkHeN,G;;AACf0C,MAAM,CAACC,OAAP,GAAiB3C,GAAjB"}