Socket
Socket
Sign inDemoInstall

tedious

Package Overview
Dependencies
106
Maintainers
8
Versions
214
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 13.0.4 to 13.0.5

12

lib/bulk-load.js

@@ -114,6 +114,8 @@ "use strict";

try {
value = c.type.validate(value, c.collation);
} catch (error) {
return callback(error);
if (!this.bulkLoad.firstRowWritten) {
try {
value = c.type.validate(value, c.collation);
} catch (error) {
return callback(error);
}
}

@@ -669,2 +671,2 @@

module.exports = BulkLoad;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/bulk-load.ts"],"names":["FLAGS","nullable","caseSen","updateableReadWrite","updateableUnknown","identity","computed","fixedLenCLRType","sparseColumnSet","hidden","key","nullableUnknown","DONE_STATUS","FINAL","MORE","ERROR","INXACT","COUNT","ATTN","SRVERROR","rowTokenBuffer","Buffer","from","TOKEN_TYPE","ROW","textPointerAndTimestampBuffer","textPointerNullBuffer","RowTransform","Transform","constructor","bulkLoad","writableObjectMode","columnMetadataWritten","mainOptions","columns","options","_transform","row","_encoding","callback","push","getColMetaData","i","length","c","value","Array","isArray","objName","type","validate","collation","error","parameter","scale","precision","name","generateParameterLength","chunk","generateParameterData","process","nextTick","_flush","createDoneToken","BulkLoad","EventEmitter","table","connectionOptions","checkConstraints","fireTriggers","keepNulls","lockTable","order","TypeError","column","direction","Object","entries","canceled","executionStarted","streamingMode","timeout","columnsByName","firstRowWritten","rowToPacketTransform","bulkOptions","connection","rows","rst","rowCount","undefined","addColumn","output","Error","id","resolveLength","resolvePrecision","resolveScale","addRow","input","write","map","getOptionsSql","addOptions","orderColumns","join","getBulkInsertSql","sql","len","declaration","getTableCreationSql","tBuf","WritableTrackingBuffer","writeUInt8","COLMETADATA","writeUInt16LE","j","tdsVersion","writeUInt32LE","flags","writeBuffer","generateTypeInfo","hasTableName","writeUsVarchar","writeBVarchar","data","setTimeout","DONE","status","getRowStream","cancel","emit","module","exports"],"mappings":"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","sourcesContent":["import { EventEmitter } from 'events';\nimport WritableTrackingBuffer from './tracking-buffer/writable-tracking-buffer';\nimport Connection, { InternalConnectionOptions } from './connection';\n\nimport { Transform } from 'stream';\nimport { TYPE as TOKEN_TYPE } from './token/token';\n\nimport { DataType, Parameter } from './data-type';\nimport { Collation } from './collation';\n\n/**\n * @private\n */\nconst FLAGS = {\n  nullable: 1 << 0,\n  caseSen: 1 << 1,\n  updateableReadWrite: 1 << 2,\n  updateableUnknown: 1 << 3,\n  identity: 1 << 4,\n  computed: 1 << 5, // introduced in TDS 7.2\n  fixedLenCLRType: 1 << 8, // introduced in TDS 7.2\n  sparseColumnSet: 1 << 10, // introduced in TDS 7.3.B\n  hidden: 1 << 13, // introduced in TDS 7.2\n  key: 1 << 14, // introduced in TDS 7.2\n  nullableUnknown: 1 << 15 // introduced in TDS 7.2\n};\n\n/**\n * @private\n */\nconst DONE_STATUS = {\n  FINAL: 0x00,\n  MORE: 0x1,\n  ERROR: 0x2,\n  INXACT: 0x4,\n  COUNT: 0x10,\n  ATTN: 0x20,\n  SRVERROR: 0x100\n};\n\n/**\n * @private\n */\ninterface InternalOptions {\n  checkConstraints: boolean;\n  fireTriggers: boolean;\n  keepNulls: boolean;\n  lockTable: boolean;\n  order: { [columnName: string]: 'ASC' | 'DESC' };\n}\n\nexport interface Options {\n  /**\n   * Honors constraints during bulk load, using T-SQL\n   * [CHECK_CONSTRAINTS](https://technet.microsoft.com/en-us/library/ms186247(v=sql.105).aspx).\n   * (default: `false`)\n   */\n  checkConstraints?: InternalOptions['checkConstraints'] | undefined;\n\n  /**\n   * Honors insert triggers during bulk load, using the T-SQL [FIRE_TRIGGERS](https://technet.microsoft.com/en-us/library/ms187640(v=sql.105).aspx). (default: `false`)\n   */\n  fireTriggers?: InternalOptions['fireTriggers'] | undefined;\n\n  /**\n   * Honors null value passed, ignores the default values set on table, using T-SQL [KEEP_NULLS](https://msdn.microsoft.com/en-us/library/ms187887(v=sql.120).aspx). (default: `false`)\n   */\n  keepNulls?: InternalOptions['keepNulls'] | undefined;\n\n  /**\n   * Places a bulk update(BU) lock on table while performing bulk load, using T-SQL [TABLOCK](https://technet.microsoft.com/en-us/library/ms180876(v=sql.105).aspx). (default: `false`)\n   */\n  lockTable?: InternalOptions['lockTable'] | undefined;\n\n  /**\n   * Specifies the ordering of the data to possibly increase bulk insert performance, using T-SQL [ORDER](https://docs.microsoft.com/en-us/previous-versions/sql/sql-server-2008-r2/ms177468(v=sql.105)). (default: `{}`)\n   */\n  order?: InternalOptions['order'] | undefined;\n}\n\n\nexport type Callback =\n  /**\n   * A function which will be called after the [[BulkLoad]] finishes executing.\n   *\n   * @param rowCount the number of rows inserted\n   */\n  (err: Error | undefined | null, rowCount?: number) => void;\n\ninterface Column extends Parameter {\n  objName: string;\n  collation: Collation | undefined;\n}\n\ninterface ColumnOptions {\n  output?: boolean;\n\n  /**\n   * For VarChar, NVarChar, VarBinary. Use length as `Infinity` for VarChar(max), NVarChar(max) and VarBinary(max).\n   */\n  length?: number;\n\n  /**\n   * For Numeric, Decimal.\n   */\n  precision?: number;\n\n  /**\n   * For Numeric, Decimal, Time, DateTime2, DateTimeOffset.\n   */\n  scale?: number;\n\n  /**\n   * If the name of the column is different from the name of the property found on `rowObj` arguments passed to [[addRow]], then you can use this option to specify the property name.\n   */\n  objName?: string;\n\n  /**\n   * Indicates whether the column accepts NULL values.\n   */\n  nullable?: boolean;\n}\n\nconst rowTokenBuffer = Buffer.from([ TOKEN_TYPE.ROW ]);\nconst textPointerAndTimestampBuffer = Buffer.from([\n  // TextPointer length\n  0x10,\n\n  // TextPointer\n  0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\n\n  // Timestamp\n  0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00\n]);\nconst textPointerNullBuffer = Buffer.from([0x00]);\n\n// A transform that converts rows to packets.\nclass RowTransform extends Transform {\n  /**\n   * @private\n   */\n  columnMetadataWritten: boolean;\n  /**\n   * @private\n   */\n  bulkLoad: BulkLoad;\n  /**\n   * @private\n   */\n  mainOptions: BulkLoad['options'];\n  /**\n   * @private\n   */\n  columns: BulkLoad['columns'];\n\n  /**\n   * @private\n   */\n  constructor(bulkLoad: BulkLoad) {\n    super({ writableObjectMode: true });\n\n    this.bulkLoad = bulkLoad;\n    this.mainOptions = bulkLoad.options;\n    this.columns = bulkLoad.columns;\n\n    this.columnMetadataWritten = false;\n  }\n\n  /**\n   * @private\n   */\n  _transform(row: Array<unknown> | { [colName: string]: unknown }, _encoding: string, callback: (error?: Error) => void) {\n    if (!this.columnMetadataWritten) {\n      this.push(this.bulkLoad.getColMetaData());\n      this.columnMetadataWritten = true;\n    }\n\n    this.push(rowTokenBuffer);\n\n    for (let i = 0; i < this.columns.length; i++) {\n      const c = this.columns[i];\n      let value = Array.isArray(row) ? row[i] : row[c.objName];\n\n      try {\n        value = c.type.validate(value, c.collation);\n      } catch (error: any) {\n        return callback(error);\n      }\n\n      const parameter = {\n        length: c.length,\n        scale: c.scale,\n        precision: c.precision,\n        value: value\n      };\n\n      if (c.type.name === 'Text' || c.type.name === 'Image' || c.type.name === 'NText') {\n        if (value == null) {\n          this.push(textPointerNullBuffer);\n          continue;\n        }\n\n        this.push(textPointerAndTimestampBuffer);\n      }\n\n      this.push(c.type.generateParameterLength(parameter, this.mainOptions));\n      for (const chunk of c.type.generateParameterData(parameter, this.mainOptions)) {\n        this.push(chunk);\n      }\n    }\n\n    process.nextTick(callback);\n  }\n\n  /**\n   * @private\n   */\n  _flush(callback: () => void) {\n    this.push(this.bulkLoad.createDoneToken());\n\n    process.nextTick(callback);\n  }\n}\n\n/**\n * A BulkLoad instance is used to perform a bulk insert.\n *\n * Use [[Connection.newBulkLoad]] to create a new instance, and [[Connection.execBulkLoad]] to execute it.\n *\n * Example of BulkLoad Usages:\n *\n * ```js\n * // optional BulkLoad options\n * const options = { keepNulls: true };\n *\n * // instantiate - provide the table where you'll be inserting to, options and a callback\n * const bulkLoad = connection.newBulkLoad('MyTable', options, (error, rowCount) => {\n *   console.log('inserted %d rows', rowCount);\n * });\n *\n * // setup your columns - always indicate whether the column is nullable\n * bulkLoad.addColumn('myInt', TYPES.Int, { nullable: false });\n * bulkLoad.addColumn('myString', TYPES.NVarChar, { length: 50, nullable: true });\n *\n * // execute\n * connection.execBulkLoad(bulkLoad, [\n *   { myInt: 7, myString: 'hello' },\n *   { myInt: 23, myString: 'world' }\n * ]);\n * ```\n */\nclass BulkLoad extends EventEmitter {\n  /**\n   * @private\n   */\n  error: Error | undefined;\n  /**\n   * @private\n   */\n  canceled: boolean;\n  /**\n   * @private\n   */\n  executionStarted: boolean;\n  /**\n   * @private\n   */\n  streamingMode: boolean;\n  /**\n   * @private\n   */\n  table: string;\n  /**\n   * @private\n   */\n  timeout: number | undefined;\n\n  /**\n   * @private\n   */\n  options: InternalConnectionOptions;\n  /**\n   * @private\n   */\n  callback: Callback;\n\n  /**\n   * @private\n   */\n  columns: Array<Column>;\n  /**\n   * @private\n   */\n  columnsByName: { [name: string]: Column };\n\n  /**\n   * @private\n   */\n  firstRowWritten: boolean;\n  /**\n   * @private\n   */\n  rowToPacketTransform: RowTransform;\n\n  /**\n   * @private\n   */\n  bulkOptions: InternalOptions;\n\n  /**\n   * @private\n   */\n  connection: Connection | undefined;\n  /**\n   * @private\n   */\n  rows: Array<any> | undefined;\n  /**\n   * @private\n   */\n  rst: Array<any> | undefined;\n  /**\n   * @private\n   */\n  rowCount: number | undefined;\n\n  collation: Collation | undefined;\n\n  /**\n   * @private\n   */\n  constructor(table: string, collation: Collation | undefined, connectionOptions: InternalConnectionOptions, {\n    checkConstraints = false,\n    fireTriggers = false,\n    keepNulls = false,\n    lockTable = false,\n    order = {},\n  }: Options, callback: Callback) {\n    if (typeof checkConstraints !== 'boolean') {\n      throw new TypeError('The \"options.checkConstraints\" property must be of type boolean.');\n    }\n\n    if (typeof fireTriggers !== 'boolean') {\n      throw new TypeError('The \"options.fireTriggers\" property must be of type boolean.');\n    }\n\n    if (typeof keepNulls !== 'boolean') {\n      throw new TypeError('The \"options.keepNulls\" property must be of type boolean.');\n    }\n\n    if (typeof lockTable !== 'boolean') {\n      throw new TypeError('The \"options.lockTable\" property must be of type boolean.');\n    }\n\n    if (typeof order !== 'object' || order === null) {\n      throw new TypeError('The \"options.order\" property must be of type object.');\n    }\n\n    for (const [column, direction] of Object.entries(order)) {\n      if (direction !== 'ASC' && direction !== 'DESC') {\n        throw new TypeError('The value of the \"' + column + '\" key in the \"options.order\" object must be either \"ASC\" or \"DESC\".');\n      }\n    }\n\n    super();\n\n    this.error = undefined;\n    this.canceled = false;\n    this.executionStarted = false;\n\n    this.collation = collation;\n\n    this.table = table;\n    this.options = connectionOptions;\n    this.callback = callback;\n    this.columns = [];\n    this.columnsByName = {};\n    this.firstRowWritten = false;\n    this.streamingMode = false;\n\n    this.rowToPacketTransform = new RowTransform(this); // eslint-disable-line no-use-before-define\n\n    this.bulkOptions = { checkConstraints, fireTriggers, keepNulls, lockTable, order };\n  }\n\n  /**\n   * Adds a column to the bulk load.\n   *\n   * The column definitions should match the table you are trying to insert into.\n   * Attempting to call addColumn after the first row has been added will throw an exception.\n   *\n   * ```js\n   * bulkLoad.addColumn('MyIntColumn', TYPES.Int, { nullable: false });\n   * ```\n   *\n   * @param name The name of the column.\n   * @param type One of the supported `data types`.\n   * @param __namedParameters Additional column type information. At a minimum, `nullable` must be set to true or false.\n   * @param length For VarChar, NVarChar, VarBinary. Use length as `Infinity` for VarChar(max), NVarChar(max) and VarBinary(max).\n   * @param nullable Indicates whether the column accepts NULL values.\n   * @param objName If the name of the column is different from the name of the property found on `rowObj` arguments passed to [[addRow]] or [[Connection.execBulkLoad]], then you can use this option to specify the property name.\n   * @param precision For Numeric, Decimal.\n   * @param scale For Numeric, Decimal, Time, DateTime2, DateTimeOffset.\n  */\n  addColumn(name: string, type: DataType, { output = false, length, precision, scale, objName = name, nullable = true }: ColumnOptions) {\n    if (this.firstRowWritten) {\n      throw new Error('Columns cannot be added to bulk insert after the first row has been written.');\n    }\n    if (this.executionStarted) {\n      throw new Error('Columns cannot be added to bulk insert after execution has started.');\n    }\n\n    const column: Column = {\n      type: type,\n      name: name,\n      value: null,\n      output: output,\n      length: length,\n      precision: precision,\n      scale: scale,\n      objName: objName,\n      nullable: nullable,\n      collation: this.collation\n    };\n\n    if ((type.id & 0x30) === 0x20) {\n      if (column.length == null && type.resolveLength) {\n        column.length = type.resolveLength(column);\n      }\n    }\n\n    if (type.resolvePrecision && column.precision == null) {\n      column.precision = type.resolvePrecision(column);\n    }\n\n    if (type.resolveScale && column.scale == null) {\n      column.scale = type.resolveScale(column);\n    }\n\n    this.columns.push(column);\n\n    this.columnsByName[name] = column;\n  }\n\n  /**\n   * Adds a row to the bulk insert.\n   *\n   * ```js\n   * bulkLoad.addRow({ first_name: 'Bill', last_name: 'Gates' });\n   * ```\n   *\n   * @param row An object of key/value pairs representing column name (or objName) and value.\n   *\n   * @deprecated This method is deprecated. Instead of adding rows individually, you should pass\n   *   all row objects when calling [[Connection.execBulkLoad]]. This method will be removed in the future.\n   */\n  addRow(row: { [columnName: string]: unknown }): void\n\n  /**\n   * Adds a row to the bulk insert.\n   *\n   * ```js\n   * bulkLoad.addRow('Bill', 'Gates');\n   * ```\n   *\n   * @param row If there are at least two columns, values can be passed as multiple arguments instead of an array. They\n   *   must be in the same order the columns were added in.\n   *\n   * @deprecated This method is deprecated. Instead of adding rows individually, you should pass\n   *   all row objects when calling [[Connection.execBulkLoad]]. This method will be removed in the future.\n   */\n  addRow(...row: unknown[]): void\n\n  /**\n   * Adds a row to the bulk insert.\n   *\n   * ```js\n   * bulkLoad.addRow(['Bill', 'Gates']);\n   * ```\n   *\n   * @param row An array representing the values of each column in the same order which they were added to the bulkLoad object.\n   *\n   * @deprecated This method is deprecated. Instead of adding rows individually, you should pass\n   *   all row objects when calling [[Connection.execBulkLoad]]. This method will be removed in the future.\n   */\n  addRow(row: unknown[]): void\n\n  addRow(...input: [ { [key: string]: unknown } ] | unknown[]) {\n    this.firstRowWritten = true;\n\n    let row: any;\n    if (input.length > 1 || !input[0] || typeof input[0] !== 'object') {\n      row = input;\n    } else {\n      row = input[0];\n    }\n\n    // write each column\n    if (Array.isArray(row)) {\n      this.rowToPacketTransform.write(this.columns.map((column, i) => {\n        return column.type.validate(row[i], column.collation);\n      }));\n    } else {\n      this.rowToPacketTransform.write(this.columns.map((column) => {\n        return column.type.validate(row[column.objName], column.collation);\n      }));\n    }\n  }\n\n  /**\n   * @private\n   */\n  getOptionsSql() {\n    const addOptions = [];\n\n    if (this.bulkOptions.checkConstraints) {\n      addOptions.push('CHECK_CONSTRAINTS');\n    }\n\n    if (this.bulkOptions.fireTriggers) {\n      addOptions.push('FIRE_TRIGGERS');\n    }\n\n    if (this.bulkOptions.keepNulls) {\n      addOptions.push('KEEP_NULLS');\n    }\n\n    if (this.bulkOptions.lockTable) {\n      addOptions.push('TABLOCK');\n    }\n\n    if (this.bulkOptions.order) {\n      const orderColumns = [];\n\n      for (const [column, direction] of Object.entries(this.bulkOptions.order)) {\n        orderColumns.push(`${column} ${direction}`);\n      }\n\n      if (orderColumns.length) {\n        addOptions.push(`ORDER (${orderColumns.join(', ')})`);\n      }\n    }\n\n    if (addOptions.length > 0) {\n      return ` WITH (${addOptions.join(',')})`;\n    } else {\n      return '';\n    }\n  }\n\n  /**\n   * @private\n   */\n  getBulkInsertSql() {\n    let sql = 'insert bulk ' + this.table + '(';\n    for (let i = 0, len = this.columns.length; i < len; i++) {\n      const c = this.columns[i];\n      if (i !== 0) {\n        sql += ', ';\n      }\n      sql += '[' + c.name + '] ' + (c.type.declaration(c));\n    }\n    sql += ')';\n\n    sql += this.getOptionsSql();\n    return sql;\n  }\n\n  /**\n   * This is simply a helper utility function which returns a `CREATE TABLE SQL` statement based on the columns added to the bulkLoad object.\n   * This may be particularly handy when you want to insert into a temporary table (a table which starts with `#`).\n   *\n   * ```js\n   * var sql = bulkLoad.getTableCreationSql();\n   * ```\n   *\n   * A side note on bulk inserting into temporary tables: if you want to access a local temporary table after executing the bulk load,\n   * you'll need to use the same connection and execute your requests using [[Connection.execSqlBatch]] instead of [[Connection.execSql]]\n   */\n  getTableCreationSql() {\n    let sql = 'CREATE TABLE ' + this.table + '(\\n';\n    for (let i = 0, len = this.columns.length; i < len; i++) {\n      const c = this.columns[i];\n      if (i !== 0) {\n        sql += ',\\n';\n      }\n      sql += '[' + c.name + '] ' + (c.type.declaration(c));\n      if (c.nullable !== undefined) {\n        sql += ' ' + (c.nullable ? 'NULL' : 'NOT NULL');\n      }\n    }\n    sql += '\\n)';\n    return sql;\n  }\n\n  /**\n   * @private\n   */\n  getColMetaData() {\n    const tBuf = new WritableTrackingBuffer(100, null, true);\n    // TokenType\n    tBuf.writeUInt8(TOKEN_TYPE.COLMETADATA);\n    // Count\n    tBuf.writeUInt16LE(this.columns.length);\n\n    for (let j = 0, len = this.columns.length; j < len; j++) {\n      const c = this.columns[j];\n      // UserType\n      if (this.options.tdsVersion < '7_2') {\n        tBuf.writeUInt16LE(0);\n      } else {\n        tBuf.writeUInt32LE(0);\n      }\n\n      // Flags\n      let flags = FLAGS.updateableReadWrite;\n      if (c.nullable) {\n        flags |= FLAGS.nullable;\n      } else if (c.nullable === undefined && this.options.tdsVersion >= '7_2') {\n        flags |= FLAGS.nullableUnknown;\n      }\n      tBuf.writeUInt16LE(flags);\n\n      // TYPE_INFO\n      tBuf.writeBuffer(c.type.generateTypeInfo(c, this.options));\n\n      // TableName\n      if (c.type.hasTableName) {\n        tBuf.writeUsVarchar(this.table, 'ucs2');\n      }\n\n      // ColName\n      tBuf.writeBVarchar(c.name, 'ucs2');\n    }\n    return tBuf.data;\n  }\n\n  /**\n   * Sets a timeout for this bulk load.\n   *\n   * ```js\n   * bulkLoad.setTimeout(timeout);\n   * ```\n   *\n   * @param timeout The number of milliseconds before the bulk load is considered failed, or 0 for no timeout.\n   *   When no timeout is set for the bulk load, the [[ConnectionOptions.requestTimeout]] of the Connection is used.\n   */\n  setTimeout(timeout?: number) {\n    this.timeout = timeout;\n  }\n\n  /**\n   * @private\n   */\n  createDoneToken() {\n    // It might be nice to make DoneToken a class if anything needs to create them, but for now, just do it here\n    const tBuf = new WritableTrackingBuffer(this.options.tdsVersion < '7_2' ? 9 : 13);\n    tBuf.writeUInt8(TOKEN_TYPE.DONE);\n    const status = DONE_STATUS.FINAL;\n    tBuf.writeUInt16LE(status);\n    tBuf.writeUInt16LE(0); // CurCmd (TDS ignores this)\n    tBuf.writeUInt32LE(0); // row count - doesn't really matter\n    if (this.options.tdsVersion >= '7_2') {\n      tBuf.writeUInt32LE(0); // row count is 64 bits in >= TDS 7.2\n    }\n    return tBuf.data;\n  }\n\n  /**\n   * Switches the `BulkLoad` object into streaming mode and returns a\n   * [writable stream](https://nodejs.org/dist/latest-v10.x/docs/api/stream.html#stream_writable_streams)\n   * that can be used to send a large amount of rows to the server.\n   *\n   * ```js\n   * const bulkLoad = connection.newBulkLoad(...);\n   * bulkLoad.addColumn(...);\n   *\n   * const rowStream = bulkLoad.getRowStream();\n   *\n   * connection.execBulkLoad(bulkLoad);\n   * ```\n   *\n   * In streaming mode, [[addRow]] cannot be used. Instead all data rows must be written to the returned stream object.\n   * The stream implementation uses data flow control to prevent memory overload. [`stream.write()`](https://nodejs.org/dist/latest-v10.x/docs/api/stream.html#stream_writable_write_chunk_encoding_callback)\n   * returns `false` to indicate that data transfer should be paused.\n   *\n   * After that, the stream emits a ['drain' event](https://nodejs.org/dist/latest-v10.x/docs/api/stream.html#stream_event_drain)\n   * when it is ready to resume data transfer.\n   *\n   * @deprecated\n   *   This method is deprecated. Instead of writing rows to the stream returned by this method,\n   *   you can pass any object that implements the `Iterable` or `AsyncIterable` interface (e.g. a `Readable`\n   *   stream or an `AsyncGenerator`) when calling [[Connection.execBulkLoad]]. This method will be removed in the future.\n   */\n  getRowStream() {\n    if (this.firstRowWritten) {\n      throw new Error('BulkLoad cannot be switched to streaming mode after first row has been written using addRow().');\n    }\n    if (this.executionStarted) {\n      throw new Error('BulkLoad cannot be switched to streaming mode after execution has started.');\n    }\n    this.streamingMode = true;\n\n    return this.rowToPacketTransform;\n  }\n\n  /**\n   * @private\n   */\n  cancel() {\n    if (this.canceled) {\n      return;\n    }\n\n    this.canceled = true;\n    this.emit('cancel');\n  }\n}\n\nexport default BulkLoad;\nmodule.exports = BulkLoad;\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/bulk-load.ts"],"names":["FLAGS","nullable","caseSen","updateableReadWrite","updateableUnknown","identity","computed","fixedLenCLRType","sparseColumnSet","hidden","key","nullableUnknown","DONE_STATUS","FINAL","MORE","ERROR","INXACT","COUNT","ATTN","SRVERROR","rowTokenBuffer","Buffer","from","TOKEN_TYPE","ROW","textPointerAndTimestampBuffer","textPointerNullBuffer","RowTransform","Transform","constructor","bulkLoad","writableObjectMode","columnMetadataWritten","mainOptions","columns","options","_transform","row","_encoding","callback","push","getColMetaData","i","length","c","value","Array","isArray","objName","firstRowWritten","type","validate","collation","error","parameter","scale","precision","name","generateParameterLength","chunk","generateParameterData","process","nextTick","_flush","createDoneToken","BulkLoad","EventEmitter","table","connectionOptions","checkConstraints","fireTriggers","keepNulls","lockTable","order","TypeError","column","direction","Object","entries","canceled","executionStarted","streamingMode","timeout","columnsByName","rowToPacketTransform","bulkOptions","connection","rows","rst","rowCount","undefined","addColumn","output","Error","id","resolveLength","resolvePrecision","resolveScale","addRow","input","write","map","getOptionsSql","addOptions","orderColumns","join","getBulkInsertSql","sql","len","declaration","getTableCreationSql","tBuf","WritableTrackingBuffer","writeUInt8","COLMETADATA","writeUInt16LE","j","tdsVersion","writeUInt32LE","flags","writeBuffer","generateTypeInfo","hasTableName","writeUsVarchar","writeBVarchar","data","setTimeout","DONE","status","getRowStream","cancel","emit","module","exports"],"mappings":"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","sourcesContent":["import { EventEmitter } from 'events';\nimport WritableTrackingBuffer from './tracking-buffer/writable-tracking-buffer';\nimport Connection, { InternalConnectionOptions } from './connection';\n\nimport { Transform } from 'stream';\nimport { TYPE as TOKEN_TYPE } from './token/token';\n\nimport { DataType, Parameter } from './data-type';\nimport { Collation } from './collation';\n\n/**\n * @private\n */\nconst FLAGS = {\n  nullable: 1 << 0,\n  caseSen: 1 << 1,\n  updateableReadWrite: 1 << 2,\n  updateableUnknown: 1 << 3,\n  identity: 1 << 4,\n  computed: 1 << 5, // introduced in TDS 7.2\n  fixedLenCLRType: 1 << 8, // introduced in TDS 7.2\n  sparseColumnSet: 1 << 10, // introduced in TDS 7.3.B\n  hidden: 1 << 13, // introduced in TDS 7.2\n  key: 1 << 14, // introduced in TDS 7.2\n  nullableUnknown: 1 << 15 // introduced in TDS 7.2\n};\n\n/**\n * @private\n */\nconst DONE_STATUS = {\n  FINAL: 0x00,\n  MORE: 0x1,\n  ERROR: 0x2,\n  INXACT: 0x4,\n  COUNT: 0x10,\n  ATTN: 0x20,\n  SRVERROR: 0x100\n};\n\n/**\n * @private\n */\ninterface InternalOptions {\n  checkConstraints: boolean;\n  fireTriggers: boolean;\n  keepNulls: boolean;\n  lockTable: boolean;\n  order: { [columnName: string]: 'ASC' | 'DESC' };\n}\n\nexport interface Options {\n  /**\n   * Honors constraints during bulk load, using T-SQL\n   * [CHECK_CONSTRAINTS](https://technet.microsoft.com/en-us/library/ms186247(v=sql.105).aspx).\n   * (default: `false`)\n   */\n  checkConstraints?: InternalOptions['checkConstraints'] | undefined;\n\n  /**\n   * Honors insert triggers during bulk load, using the T-SQL [FIRE_TRIGGERS](https://technet.microsoft.com/en-us/library/ms187640(v=sql.105).aspx). (default: `false`)\n   */\n  fireTriggers?: InternalOptions['fireTriggers'] | undefined;\n\n  /**\n   * Honors null value passed, ignores the default values set on table, using T-SQL [KEEP_NULLS](https://msdn.microsoft.com/en-us/library/ms187887(v=sql.120).aspx). (default: `false`)\n   */\n  keepNulls?: InternalOptions['keepNulls'] | undefined;\n\n  /**\n   * Places a bulk update(BU) lock on table while performing bulk load, using T-SQL [TABLOCK](https://technet.microsoft.com/en-us/library/ms180876(v=sql.105).aspx). (default: `false`)\n   */\n  lockTable?: InternalOptions['lockTable'] | undefined;\n\n  /**\n   * Specifies the ordering of the data to possibly increase bulk insert performance, using T-SQL [ORDER](https://docs.microsoft.com/en-us/previous-versions/sql/sql-server-2008-r2/ms177468(v=sql.105)). (default: `{}`)\n   */\n  order?: InternalOptions['order'] | undefined;\n}\n\n\nexport type Callback =\n  /**\n   * A function which will be called after the [[BulkLoad]] finishes executing.\n   *\n   * @param rowCount the number of rows inserted\n   */\n  (err: Error | undefined | null, rowCount?: number) => void;\n\ninterface Column extends Parameter {\n  objName: string;\n  collation: Collation | undefined;\n}\n\ninterface ColumnOptions {\n  output?: boolean;\n\n  /**\n   * For VarChar, NVarChar, VarBinary. Use length as `Infinity` for VarChar(max), NVarChar(max) and VarBinary(max).\n   */\n  length?: number;\n\n  /**\n   * For Numeric, Decimal.\n   */\n  precision?: number;\n\n  /**\n   * For Numeric, Decimal, Time, DateTime2, DateTimeOffset.\n   */\n  scale?: number;\n\n  /**\n   * If the name of the column is different from the name of the property found on `rowObj` arguments passed to [[addRow]], then you can use this option to specify the property name.\n   */\n  objName?: string;\n\n  /**\n   * Indicates whether the column accepts NULL values.\n   */\n  nullable?: boolean;\n}\n\nconst rowTokenBuffer = Buffer.from([ TOKEN_TYPE.ROW ]);\nconst textPointerAndTimestampBuffer = Buffer.from([\n  // TextPointer length\n  0x10,\n\n  // TextPointer\n  0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\n\n  // Timestamp\n  0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00\n]);\nconst textPointerNullBuffer = Buffer.from([0x00]);\n\n// A transform that converts rows to packets.\nclass RowTransform extends Transform {\n  /**\n   * @private\n   */\n  columnMetadataWritten: boolean;\n  /**\n   * @private\n   */\n  bulkLoad: BulkLoad;\n  /**\n   * @private\n   */\n  mainOptions: BulkLoad['options'];\n  /**\n   * @private\n   */\n  columns: BulkLoad['columns'];\n\n  /**\n   * @private\n   */\n  constructor(bulkLoad: BulkLoad) {\n    super({ writableObjectMode: true });\n\n    this.bulkLoad = bulkLoad;\n    this.mainOptions = bulkLoad.options;\n    this.columns = bulkLoad.columns;\n\n    this.columnMetadataWritten = false;\n  }\n\n  /**\n   * @private\n   */\n  _transform(row: Array<unknown> | { [colName: string]: unknown }, _encoding: string, callback: (error?: Error) => void) {\n    if (!this.columnMetadataWritten) {\n      this.push(this.bulkLoad.getColMetaData());\n      this.columnMetadataWritten = true;\n    }\n\n    this.push(rowTokenBuffer);\n\n    for (let i = 0; i < this.columns.length; i++) {\n      const c = this.columns[i];\n      let value = Array.isArray(row) ? row[i] : row[c.objName];\n\n      if (!this.bulkLoad.firstRowWritten) {\n        try {\n          value = c.type.validate(value, c.collation);\n        } catch (error: any) {\n          return callback(error);\n        }\n      }\n\n      const parameter = {\n        length: c.length,\n        scale: c.scale,\n        precision: c.precision,\n        value: value\n      };\n\n      if (c.type.name === 'Text' || c.type.name === 'Image' || c.type.name === 'NText') {\n        if (value == null) {\n          this.push(textPointerNullBuffer);\n          continue;\n        }\n\n        this.push(textPointerAndTimestampBuffer);\n      }\n\n      this.push(c.type.generateParameterLength(parameter, this.mainOptions));\n      for (const chunk of c.type.generateParameterData(parameter, this.mainOptions)) {\n        this.push(chunk);\n      }\n    }\n\n    process.nextTick(callback);\n  }\n\n  /**\n   * @private\n   */\n  _flush(callback: () => void) {\n    this.push(this.bulkLoad.createDoneToken());\n\n    process.nextTick(callback);\n  }\n}\n\n/**\n * A BulkLoad instance is used to perform a bulk insert.\n *\n * Use [[Connection.newBulkLoad]] to create a new instance, and [[Connection.execBulkLoad]] to execute it.\n *\n * Example of BulkLoad Usages:\n *\n * ```js\n * // optional BulkLoad options\n * const options = { keepNulls: true };\n *\n * // instantiate - provide the table where you'll be inserting to, options and a callback\n * const bulkLoad = connection.newBulkLoad('MyTable', options, (error, rowCount) => {\n *   console.log('inserted %d rows', rowCount);\n * });\n *\n * // setup your columns - always indicate whether the column is nullable\n * bulkLoad.addColumn('myInt', TYPES.Int, { nullable: false });\n * bulkLoad.addColumn('myString', TYPES.NVarChar, { length: 50, nullable: true });\n *\n * // execute\n * connection.execBulkLoad(bulkLoad, [\n *   { myInt: 7, myString: 'hello' },\n *   { myInt: 23, myString: 'world' }\n * ]);\n * ```\n */\nclass BulkLoad extends EventEmitter {\n  /**\n   * @private\n   */\n  error: Error | undefined;\n  /**\n   * @private\n   */\n  canceled: boolean;\n  /**\n   * @private\n   */\n  executionStarted: boolean;\n  /**\n   * @private\n   */\n  streamingMode: boolean;\n  /**\n   * @private\n   */\n  table: string;\n  /**\n   * @private\n   */\n  timeout: number | undefined;\n\n  /**\n   * @private\n   */\n  options: InternalConnectionOptions;\n  /**\n   * @private\n   */\n  callback: Callback;\n\n  /**\n   * @private\n   */\n  columns: Array<Column>;\n  /**\n   * @private\n   */\n  columnsByName: { [name: string]: Column };\n\n  /**\n   * @private\n   */\n  firstRowWritten: boolean;\n  /**\n   * @private\n   */\n  rowToPacketTransform: RowTransform;\n\n  /**\n   * @private\n   */\n  bulkOptions: InternalOptions;\n\n  /**\n   * @private\n   */\n  connection: Connection | undefined;\n  /**\n   * @private\n   */\n  rows: Array<any> | undefined;\n  /**\n   * @private\n   */\n  rst: Array<any> | undefined;\n  /**\n   * @private\n   */\n  rowCount: number | undefined;\n\n  collation: Collation | undefined;\n\n  /**\n   * @private\n   */\n  constructor(table: string, collation: Collation | undefined, connectionOptions: InternalConnectionOptions, {\n    checkConstraints = false,\n    fireTriggers = false,\n    keepNulls = false,\n    lockTable = false,\n    order = {},\n  }: Options, callback: Callback) {\n    if (typeof checkConstraints !== 'boolean') {\n      throw new TypeError('The \"options.checkConstraints\" property must be of type boolean.');\n    }\n\n    if (typeof fireTriggers !== 'boolean') {\n      throw new TypeError('The \"options.fireTriggers\" property must be of type boolean.');\n    }\n\n    if (typeof keepNulls !== 'boolean') {\n      throw new TypeError('The \"options.keepNulls\" property must be of type boolean.');\n    }\n\n    if (typeof lockTable !== 'boolean') {\n      throw new TypeError('The \"options.lockTable\" property must be of type boolean.');\n    }\n\n    if (typeof order !== 'object' || order === null) {\n      throw new TypeError('The \"options.order\" property must be of type object.');\n    }\n\n    for (const [column, direction] of Object.entries(order)) {\n      if (direction !== 'ASC' && direction !== 'DESC') {\n        throw new TypeError('The value of the \"' + column + '\" key in the \"options.order\" object must be either \"ASC\" or \"DESC\".');\n      }\n    }\n\n    super();\n\n    this.error = undefined;\n    this.canceled = false;\n    this.executionStarted = false;\n\n    this.collation = collation;\n\n    this.table = table;\n    this.options = connectionOptions;\n    this.callback = callback;\n    this.columns = [];\n    this.columnsByName = {};\n    this.firstRowWritten = false;\n    this.streamingMode = false;\n\n    this.rowToPacketTransform = new RowTransform(this); // eslint-disable-line no-use-before-define\n\n    this.bulkOptions = { checkConstraints, fireTriggers, keepNulls, lockTable, order };\n  }\n\n  /**\n   * Adds a column to the bulk load.\n   *\n   * The column definitions should match the table you are trying to insert into.\n   * Attempting to call addColumn after the first row has been added will throw an exception.\n   *\n   * ```js\n   * bulkLoad.addColumn('MyIntColumn', TYPES.Int, { nullable: false });\n   * ```\n   *\n   * @param name The name of the column.\n   * @param type One of the supported `data types`.\n   * @param __namedParameters Additional column type information. At a minimum, `nullable` must be set to true or false.\n   * @param length For VarChar, NVarChar, VarBinary. Use length as `Infinity` for VarChar(max), NVarChar(max) and VarBinary(max).\n   * @param nullable Indicates whether the column accepts NULL values.\n   * @param objName If the name of the column is different from the name of the property found on `rowObj` arguments passed to [[addRow]] or [[Connection.execBulkLoad]], then you can use this option to specify the property name.\n   * @param precision For Numeric, Decimal.\n   * @param scale For Numeric, Decimal, Time, DateTime2, DateTimeOffset.\n  */\n  addColumn(name: string, type: DataType, { output = false, length, precision, scale, objName = name, nullable = true }: ColumnOptions) {\n    if (this.firstRowWritten) {\n      throw new Error('Columns cannot be added to bulk insert after the first row has been written.');\n    }\n    if (this.executionStarted) {\n      throw new Error('Columns cannot be added to bulk insert after execution has started.');\n    }\n\n    const column: Column = {\n      type: type,\n      name: name,\n      value: null,\n      output: output,\n      length: length,\n      precision: precision,\n      scale: scale,\n      objName: objName,\n      nullable: nullable,\n      collation: this.collation\n    };\n\n    if ((type.id & 0x30) === 0x20) {\n      if (column.length == null && type.resolveLength) {\n        column.length = type.resolveLength(column);\n      }\n    }\n\n    if (type.resolvePrecision && column.precision == null) {\n      column.precision = type.resolvePrecision(column);\n    }\n\n    if (type.resolveScale && column.scale == null) {\n      column.scale = type.resolveScale(column);\n    }\n\n    this.columns.push(column);\n\n    this.columnsByName[name] = column;\n  }\n\n  /**\n   * Adds a row to the bulk insert.\n   *\n   * ```js\n   * bulkLoad.addRow({ first_name: 'Bill', last_name: 'Gates' });\n   * ```\n   *\n   * @param row An object of key/value pairs representing column name (or objName) and value.\n   *\n   * @deprecated This method is deprecated. Instead of adding rows individually, you should pass\n   *   all row objects when calling [[Connection.execBulkLoad]]. This method will be removed in the future.\n   */\n  addRow(row: { [columnName: string]: unknown }): void\n\n  /**\n   * Adds a row to the bulk insert.\n   *\n   * ```js\n   * bulkLoad.addRow('Bill', 'Gates');\n   * ```\n   *\n   * @param row If there are at least two columns, values can be passed as multiple arguments instead of an array. They\n   *   must be in the same order the columns were added in.\n   *\n   * @deprecated This method is deprecated. Instead of adding rows individually, you should pass\n   *   all row objects when calling [[Connection.execBulkLoad]]. This method will be removed in the future.\n   */\n  addRow(...row: unknown[]): void\n\n  /**\n   * Adds a row to the bulk insert.\n   *\n   * ```js\n   * bulkLoad.addRow(['Bill', 'Gates']);\n   * ```\n   *\n   * @param row An array representing the values of each column in the same order which they were added to the bulkLoad object.\n   *\n   * @deprecated This method is deprecated. Instead of adding rows individually, you should pass\n   *   all row objects when calling [[Connection.execBulkLoad]]. This method will be removed in the future.\n   */\n  addRow(row: unknown[]): void\n\n  addRow(...input: [ { [key: string]: unknown } ] | unknown[]) {\n    this.firstRowWritten = true;\n\n    let row: any;\n    if (input.length > 1 || !input[0] || typeof input[0] !== 'object') {\n      row = input;\n    } else {\n      row = input[0];\n    }\n\n    // write each column\n    if (Array.isArray(row)) {\n      this.rowToPacketTransform.write(this.columns.map((column, i) => {\n        return column.type.validate(row[i], column.collation);\n      }));\n    } else {\n      this.rowToPacketTransform.write(this.columns.map((column) => {\n        return column.type.validate(row[column.objName], column.collation);\n      }));\n    }\n  }\n\n  /**\n   * @private\n   */\n  getOptionsSql() {\n    const addOptions = [];\n\n    if (this.bulkOptions.checkConstraints) {\n      addOptions.push('CHECK_CONSTRAINTS');\n    }\n\n    if (this.bulkOptions.fireTriggers) {\n      addOptions.push('FIRE_TRIGGERS');\n    }\n\n    if (this.bulkOptions.keepNulls) {\n      addOptions.push('KEEP_NULLS');\n    }\n\n    if (this.bulkOptions.lockTable) {\n      addOptions.push('TABLOCK');\n    }\n\n    if (this.bulkOptions.order) {\n      const orderColumns = [];\n\n      for (const [column, direction] of Object.entries(this.bulkOptions.order)) {\n        orderColumns.push(`${column} ${direction}`);\n      }\n\n      if (orderColumns.length) {\n        addOptions.push(`ORDER (${orderColumns.join(', ')})`);\n      }\n    }\n\n    if (addOptions.length > 0) {\n      return ` WITH (${addOptions.join(',')})`;\n    } else {\n      return '';\n    }\n  }\n\n  /**\n   * @private\n   */\n  getBulkInsertSql() {\n    let sql = 'insert bulk ' + this.table + '(';\n    for (let i = 0, len = this.columns.length; i < len; i++) {\n      const c = this.columns[i];\n      if (i !== 0) {\n        sql += ', ';\n      }\n      sql += '[' + c.name + '] ' + (c.type.declaration(c));\n    }\n    sql += ')';\n\n    sql += this.getOptionsSql();\n    return sql;\n  }\n\n  /**\n   * This is simply a helper utility function which returns a `CREATE TABLE SQL` statement based on the columns added to the bulkLoad object.\n   * This may be particularly handy when you want to insert into a temporary table (a table which starts with `#`).\n   *\n   * ```js\n   * var sql = bulkLoad.getTableCreationSql();\n   * ```\n   *\n   * A side note on bulk inserting into temporary tables: if you want to access a local temporary table after executing the bulk load,\n   * you'll need to use the same connection and execute your requests using [[Connection.execSqlBatch]] instead of [[Connection.execSql]]\n   */\n  getTableCreationSql() {\n    let sql = 'CREATE TABLE ' + this.table + '(\\n';\n    for (let i = 0, len = this.columns.length; i < len; i++) {\n      const c = this.columns[i];\n      if (i !== 0) {\n        sql += ',\\n';\n      }\n      sql += '[' + c.name + '] ' + (c.type.declaration(c));\n      if (c.nullable !== undefined) {\n        sql += ' ' + (c.nullable ? 'NULL' : 'NOT NULL');\n      }\n    }\n    sql += '\\n)';\n    return sql;\n  }\n\n  /**\n   * @private\n   */\n  getColMetaData() {\n    const tBuf = new WritableTrackingBuffer(100, null, true);\n    // TokenType\n    tBuf.writeUInt8(TOKEN_TYPE.COLMETADATA);\n    // Count\n    tBuf.writeUInt16LE(this.columns.length);\n\n    for (let j = 0, len = this.columns.length; j < len; j++) {\n      const c = this.columns[j];\n      // UserType\n      if (this.options.tdsVersion < '7_2') {\n        tBuf.writeUInt16LE(0);\n      } else {\n        tBuf.writeUInt32LE(0);\n      }\n\n      // Flags\n      let flags = FLAGS.updateableReadWrite;\n      if (c.nullable) {\n        flags |= FLAGS.nullable;\n      } else if (c.nullable === undefined && this.options.tdsVersion >= '7_2') {\n        flags |= FLAGS.nullableUnknown;\n      }\n      tBuf.writeUInt16LE(flags);\n\n      // TYPE_INFO\n      tBuf.writeBuffer(c.type.generateTypeInfo(c, this.options));\n\n      // TableName\n      if (c.type.hasTableName) {\n        tBuf.writeUsVarchar(this.table, 'ucs2');\n      }\n\n      // ColName\n      tBuf.writeBVarchar(c.name, 'ucs2');\n    }\n    return tBuf.data;\n  }\n\n  /**\n   * Sets a timeout for this bulk load.\n   *\n   * ```js\n   * bulkLoad.setTimeout(timeout);\n   * ```\n   *\n   * @param timeout The number of milliseconds before the bulk load is considered failed, or 0 for no timeout.\n   *   When no timeout is set for the bulk load, the [[ConnectionOptions.requestTimeout]] of the Connection is used.\n   */\n  setTimeout(timeout?: number) {\n    this.timeout = timeout;\n  }\n\n  /**\n   * @private\n   */\n  createDoneToken() {\n    // It might be nice to make DoneToken a class if anything needs to create them, but for now, just do it here\n    const tBuf = new WritableTrackingBuffer(this.options.tdsVersion < '7_2' ? 9 : 13);\n    tBuf.writeUInt8(TOKEN_TYPE.DONE);\n    const status = DONE_STATUS.FINAL;\n    tBuf.writeUInt16LE(status);\n    tBuf.writeUInt16LE(0); // CurCmd (TDS ignores this)\n    tBuf.writeUInt32LE(0); // row count - doesn't really matter\n    if (this.options.tdsVersion >= '7_2') {\n      tBuf.writeUInt32LE(0); // row count is 64 bits in >= TDS 7.2\n    }\n    return tBuf.data;\n  }\n\n  /**\n   * Switches the `BulkLoad` object into streaming mode and returns a\n   * [writable stream](https://nodejs.org/dist/latest-v10.x/docs/api/stream.html#stream_writable_streams)\n   * that can be used to send a large amount of rows to the server.\n   *\n   * ```js\n   * const bulkLoad = connection.newBulkLoad(...);\n   * bulkLoad.addColumn(...);\n   *\n   * const rowStream = bulkLoad.getRowStream();\n   *\n   * connection.execBulkLoad(bulkLoad);\n   * ```\n   *\n   * In streaming mode, [[addRow]] cannot be used. Instead all data rows must be written to the returned stream object.\n   * The stream implementation uses data flow control to prevent memory overload. [`stream.write()`](https://nodejs.org/dist/latest-v10.x/docs/api/stream.html#stream_writable_write_chunk_encoding_callback)\n   * returns `false` to indicate that data transfer should be paused.\n   *\n   * After that, the stream emits a ['drain' event](https://nodejs.org/dist/latest-v10.x/docs/api/stream.html#stream_event_drain)\n   * when it is ready to resume data transfer.\n   *\n   * @deprecated\n   *   This method is deprecated. Instead of writing rows to the stream returned by this method,\n   *   you can pass any object that implements the `Iterable` or `AsyncIterable` interface (e.g. a `Readable`\n   *   stream or an `AsyncGenerator`) when calling [[Connection.execBulkLoad]]. This method will be removed in the future.\n   */\n  getRowStream() {\n    if (this.firstRowWritten) {\n      throw new Error('BulkLoad cannot be switched to streaming mode after first row has been written using addRow().');\n    }\n    if (this.executionStarted) {\n      throw new Error('BulkLoad cannot be switched to streaming mode after execution has started.');\n    }\n\n    this.streamingMode = true;\n\n    return this.rowToPacketTransform;\n  }\n\n  /**\n   * @private\n   */\n  cancel() {\n    if (this.canceled) {\n      return;\n    }\n\n    this.canceled = true;\n    this.emit('cancel');\n  }\n}\n\nexport default BulkLoad;\nmodule.exports = BulkLoad;\n"]}

@@ -30,3 +30,3 @@ {

"license": "MIT",
"version": "13.0.4",
"version": "13.0.5",
"main": "./lib/tedious.js",

@@ -33,0 +33,0 @@ "repository": {

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc