tedious
Version:
A TDS driver, for connecting to MS SQLServer databases.
134 lines (108 loc) • 12.9 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _core = require("@js-joda/core");
var _writableTrackingBuffer = _interopRequireDefault(require("../tracking-buffer/writable-tracking-buffer"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
const EPOCH_DATE = _core.LocalDate.ofYearDay(1, 1);
const NULL_LENGTH = Buffer.from([0x00]);
const DateTime2 = {
id: 0x2A,
type: 'DATETIME2N',
name: 'DateTime2',
declaration: function (parameter) {
return 'datetime2(' + this.resolveScale(parameter) + ')';
},
resolveScale: function (parameter) {
if (parameter.scale != null) {
return parameter.scale;
} else if (parameter.value === null) {
return 0;
} else {
return 7;
}
},
generateTypeInfo(parameter, _options) {
return Buffer.from([this.id, parameter.scale]);
},
generateParameterLength(parameter, options) {
if (parameter.value == null) {
return NULL_LENGTH;
}
switch (parameter.scale) {
case 0:
case 1:
case 2:
return Buffer.from([0x06]);
case 3:
case 4:
return Buffer.from([0x07]);
case 5:
case 6:
case 7:
return Buffer.from([0x08]);
default:
throw new Error('invalid scale');
}
},
*generateParameterData(parameter, options) {
if (parameter.value == null) {
return;
}
const value = parameter.value;
let scale = parameter.scale;
const buffer = new _writableTrackingBuffer.default(16);
scale = scale;
let timestamp;
if (options.useUTC) {
timestamp = ((value.getUTCHours() * 60 + value.getUTCMinutes()) * 60 + value.getUTCSeconds()) * 1000 + value.getUTCMilliseconds();
} else {
timestamp = ((value.getHours() * 60 + value.getMinutes()) * 60 + value.getSeconds()) * 1000 + value.getMilliseconds();
}
timestamp = timestamp * Math.pow(10, scale - 3);
timestamp += (value.nanosecondDelta != null ? value.nanosecondDelta : 0) * Math.pow(10, scale);
timestamp = Math.round(timestamp);
switch (scale) {
case 0:
case 1:
case 2:
buffer.writeUInt24LE(timestamp);
break;
case 3:
case 4:
buffer.writeUInt32LE(timestamp);
break;
case 5:
case 6:
case 7:
buffer.writeUInt40LE(timestamp);
}
let date;
if (options.useUTC) {
date = _core.LocalDate.of(value.getUTCFullYear(), value.getUTCMonth() + 1, value.getUTCDate());
} else {
date = _core.LocalDate.of(value.getFullYear(), value.getMonth() + 1, value.getDate());
}
const days = EPOCH_DATE.until(date, _core.ChronoUnit.DAYS);
buffer.writeUInt24LE(days);
yield buffer.data;
},
validate: function (value) {
if (value == null) {
return null;
}
if (!(value instanceof Date)) {
value = new Date(Date.parse(value));
}
if (isNaN(value)) {
throw new TypeError('Invalid date.');
}
return value;
}
};
var _default = DateTime2;
exports.default = _default;
module.exports = DateTime2;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["EPOCH_DATE","LocalDate","ofYearDay","NULL_LENGTH","Buffer","from","DateTime2","id","type","name","declaration","parameter","resolveScale","scale","value","generateTypeInfo","_options","generateParameterLength","options","Error","generateParameterData","buffer","WritableTrackingBuffer","timestamp","useUTC","getUTCHours","getUTCMinutes","getUTCSeconds","getUTCMilliseconds","getHours","getMinutes","getSeconds","getMilliseconds","Math","pow","nanosecondDelta","round","writeUInt24LE","writeUInt32LE","writeUInt40LE","date","of","getUTCFullYear","getUTCMonth","getUTCDate","getFullYear","getMonth","getDate","days","until","ChronoUnit","DAYS","data","validate","Date","parse","isNaN","TypeError","module","exports"],"sources":["../../src/data-types/datetime2.ts"],"sourcesContent":["import { DataType } from '../data-type';\nimport { ChronoUnit, LocalDate } from '@js-joda/core';\nimport WritableTrackingBuffer from '../tracking-buffer/writable-tracking-buffer';\n\nconst EPOCH_DATE = LocalDate.ofYearDay(1, 1);\nconst NULL_LENGTH = Buffer.from([0x00]);\n\nconst DateTime2: DataType & { resolveScale: NonNullable<DataType['resolveScale']> } = {\n  id: 0x2A,\n  type: 'DATETIME2N',\n  name: 'DateTime2',\n\n  declaration: function(parameter) {\n    return 'datetime2(' + (this.resolveScale(parameter)) + ')';\n  },\n\n  resolveScale: function(parameter) {\n    if (parameter.scale != null) {\n      return parameter.scale;\n    } else if (parameter.value === null) {\n      return 0;\n    } else {\n      return 7;\n    }\n  },\n\n  generateTypeInfo(parameter, _options) {\n    return Buffer.from([this.id, parameter.scale!]);\n  },\n\n  generateParameterLength(parameter, options) {\n    if (parameter.value == null) {\n      return NULL_LENGTH;\n    }\n\n    switch (parameter.scale!) {\n      case 0:\n      case 1:\n      case 2:\n        return Buffer.from([0x06]);\n\n      case 3:\n      case 4:\n        return Buffer.from([0x07]);\n\n      case 5:\n      case 6:\n      case 7:\n        return Buffer.from([0x08]);\n\n      default:\n        throw new Error('invalid scale');\n    }\n  },\n\n  *generateParameterData(parameter, options) {\n    if (parameter.value == null) {\n      return;\n    }\n\n    const value = parameter.value;\n    let scale = parameter.scale;\n\n    const buffer = new WritableTrackingBuffer(16);\n    scale = scale!;\n\n    let timestamp;\n    if (options.useUTC) {\n      timestamp = ((value.getUTCHours() * 60 + value.getUTCMinutes()) * 60 + value.getUTCSeconds()) * 1000 + value.getUTCMilliseconds();\n    } else {\n      timestamp = ((value.getHours() * 60 + value.getMinutes()) * 60 + value.getSeconds()) * 1000 + value.getMilliseconds();\n    }\n    timestamp = timestamp * Math.pow(10, scale - 3);\n    timestamp += (value.nanosecondDelta != null ? value.nanosecondDelta : 0) * Math.pow(10, scale);\n    timestamp = Math.round(timestamp);\n\n    switch (scale) {\n      case 0:\n      case 1:\n      case 2:\n        buffer.writeUInt24LE(timestamp);\n        break;\n      case 3:\n      case 4:\n        buffer.writeUInt32LE(timestamp);\n        break;\n      case 5:\n      case 6:\n      case 7:\n        buffer.writeUInt40LE(timestamp);\n    }\n\n    let date;\n    if (options.useUTC) {\n      date = LocalDate.of(value.getUTCFullYear(), value.getUTCMonth() + 1, value.getUTCDate());\n    } else {\n      date = LocalDate.of(value.getFullYear(), value.getMonth() + 1, value.getDate());\n    }\n\n    const days = EPOCH_DATE.until(date, ChronoUnit.DAYS);\n    buffer.writeUInt24LE(days);\n    yield buffer.data;\n  },\n\n  validate: function(value): null | number {\n    if (value == null) {\n      return null;\n    }\n\n    if (!(value instanceof Date)) {\n      value = new Date(Date.parse(value));\n    }\n\n    if (isNaN(value)) {\n      throw new TypeError('Invalid date.');\n    }\n\n    return value;\n  }\n};\n\nexport default DateTime2;\nmodule.exports = DateTime2;\n"],"mappings":"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"}