????

Your IP : 18.188.246.41


Current Path : C:/inetpub/vhost/binhdinhinvest.gdtvietnam.com/api/node_modules/tedious/lib/
Upload File :
Current File : C:/inetpub/vhost/binhdinhinvest.gdtvietnam.com/api/node_modules/tedious/lib/instance-lookup.js

"use strict";

Object.defineProperty(exports, "__esModule", {
  value: true
});
exports.instanceLookup = instanceLookup;
exports.parseBrowserResponse = parseBrowserResponse;

var _dns = _interopRequireDefault(require("dns"));

var _abortError = _interopRequireDefault(require("./errors/abort-error"));

var _sender = require("./sender");

var _withTimeout = require("./utils/with-timeout");

function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }

const SQL_SERVER_BROWSER_PORT = 1434;
const TIMEOUT = 2 * 1000;
const RETRIES = 3; // There are three bytes at the start of the response, whose purpose is unknown.

const MYSTERY_HEADER_LENGTH = 3;

// Most of the functionality has been determined from from jTDS's MSSqlServerInfo class.
async function instanceLookup(options) {
  const server = options.server;

  if (typeof server !== 'string') {
    throw new TypeError('Invalid arguments: "server" must be a string');
  }

  const instanceName = options.instanceName;

  if (typeof instanceName !== 'string') {
    throw new TypeError('Invalid arguments: "instanceName" must be a string');
  }

  const timeout = options.timeout === undefined ? TIMEOUT : options.timeout;

  if (typeof timeout !== 'number') {
    throw new TypeError('Invalid arguments: "timeout" must be a number');
  }

  const retries = options.retries === undefined ? RETRIES : options.retries;

  if (typeof retries !== 'number') {
    throw new TypeError('Invalid arguments: "retries" must be a number');
  }

  if (options.lookup !== undefined && typeof options.lookup !== 'function') {
    throw new TypeError('Invalid arguments: "lookup" must be a function');
  }

  const lookup = options.lookup ?? _dns.default.lookup;

  if (options.port !== undefined && typeof options.port !== 'number') {
    throw new TypeError('Invalid arguments: "port" must be a number');
  }

  const port = options.port ?? SQL_SERVER_BROWSER_PORT;
  const signal = options.signal;

  if (signal.aborted) {
    throw new _abortError.default();
  }

  let response;

  for (let i = 0; i <= retries; i++) {
    try {
      response = await (0, _withTimeout.withTimeout)(timeout, async signal => {
        const request = Buffer.from([0x02]);
        return await (0, _sender.sendMessage)(options.server, port, lookup, signal, request);
      }, signal);
    } catch (err) {
      // If the current attempt timed out, continue with the next
      if (!signal.aborted && err instanceof Error && err.name === 'TimeoutError') {
        continue;
      }

      throw err;
    }
  }

  if (!response) {
    throw new Error('Failed to get response from SQL Server Browser on ' + server);
  }

  const message = response.toString('ascii', MYSTERY_HEADER_LENGTH);
  const foundPort = parseBrowserResponse(message, instanceName);

  if (!foundPort) {
    throw new Error('Port for ' + instanceName + ' not found in ' + options.server);
  }

  return foundPort;
}

function parseBrowserResponse(response, instanceName) {
  let getPort;
  const instances = response.split(';;');

  for (let i = 0, len = instances.length; i < len; i++) {
    const instance = instances[i];
    const parts = instance.split(';');

    for (let p = 0, partsLen = parts.length; p < partsLen; p += 2) {
      const name = parts[p];
      const value = parts[p + 1];

      if (name === 'tcp' && getPort) {
        const port = parseInt(value, 10);
        return port;
      }

      if (name === 'InstanceName') {
        if (value.toUpperCase() === instanceName.toUpperCase()) {
          getPort = true;
        } else {
          getPort = false;
        }
      }
    }
  }
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["SQL_SERVER_BROWSER_PORT","TIMEOUT","RETRIES","MYSTERY_HEADER_LENGTH","instanceLookup","options","server","TypeError","instanceName","timeout","undefined","retries","lookup","dns","port","signal","aborted","AbortError","response","i","request","Buffer","from","err","Error","name","message","toString","foundPort","parseBrowserResponse","getPort","instances","split","len","length","instance","parts","p","partsLen","value","parseInt","toUpperCase"],"sources":["../src/instance-lookup.ts"],"sourcesContent":["import dns from 'dns';\nimport { AbortSignal } from 'node-abort-controller';\n\nimport AbortError from './errors/abort-error';\nimport { sendMessage } from './sender';\nimport { withTimeout } from './utils/with-timeout';\n\nconst SQL_SERVER_BROWSER_PORT = 1434;\nconst TIMEOUT = 2 * 1000;\nconst RETRIES = 3;\n// There are three bytes at the start of the response, whose purpose is unknown.\nconst MYSTERY_HEADER_LENGTH = 3;\n\ntype LookupFunction = (hostname: string, options: dns.LookupAllOptions, callback: (err: NodeJS.ErrnoException | null, addresses: dns.LookupAddress[]) => void) => void;\n\n// Most of the functionality has been determined from from jTDS's MSSqlServerInfo class.\nexport async function instanceLookup(options: { server: string, instanceName: string, timeout?: number, retries?: number, port?: number, lookup?: LookupFunction, signal: AbortSignal }) {\n  const server = options.server;\n  if (typeof server !== 'string') {\n    throw new TypeError('Invalid arguments: \"server\" must be a string');\n  }\n\n  const instanceName = options.instanceName;\n  if (typeof instanceName !== 'string') {\n    throw new TypeError('Invalid arguments: \"instanceName\" must be a string');\n  }\n\n  const timeout = options.timeout === undefined ? TIMEOUT : options.timeout;\n  if (typeof timeout !== 'number') {\n    throw new TypeError('Invalid arguments: \"timeout\" must be a number');\n  }\n\n  const retries = options.retries === undefined ? RETRIES : options.retries;\n  if (typeof retries !== 'number') {\n    throw new TypeError('Invalid arguments: \"retries\" must be a number');\n  }\n\n  if (options.lookup !== undefined && typeof options.lookup !== 'function') {\n    throw new TypeError('Invalid arguments: \"lookup\" must be a function');\n  }\n  const lookup = options.lookup ?? dns.lookup;\n\n  if (options.port !== undefined && typeof options.port !== 'number') {\n    throw new TypeError('Invalid arguments: \"port\" must be a number');\n  }\n  const port = options.port ?? SQL_SERVER_BROWSER_PORT;\n\n  const signal = options.signal;\n\n  if (signal.aborted) {\n    throw new AbortError();\n  }\n\n  let response;\n\n  for (let i = 0; i <= retries; i++) {\n    try {\n      response = await withTimeout(timeout, async (signal) => {\n        const request = Buffer.from([0x02]);\n        return await sendMessage(options.server, port, lookup, signal, request);\n      }, signal);\n    } catch (err) {\n      // If the current attempt timed out, continue with the next\n      if (!signal.aborted && err instanceof Error && err.name === 'TimeoutError') {\n        continue;\n      }\n\n      throw err;\n    }\n  }\n\n  if (!response) {\n    throw new Error('Failed to get response from SQL Server Browser on ' + server);\n  }\n\n  const message = response.toString('ascii', MYSTERY_HEADER_LENGTH);\n  const foundPort = parseBrowserResponse(message, instanceName);\n\n  if (!foundPort) {\n    throw new Error('Port for ' + instanceName + ' not found in ' + options.server);\n  }\n\n  return foundPort;\n}\n\nexport function parseBrowserResponse(response: string, instanceName: string) {\n  let getPort;\n\n  const instances = response.split(';;');\n  for (let i = 0, len = instances.length; i < len; i++) {\n    const instance = instances[i];\n    const parts = instance.split(';');\n\n    for (let p = 0, partsLen = parts.length; p < partsLen; p += 2) {\n      const name = parts[p];\n      const value = parts[p + 1];\n\n      if (name === 'tcp' && getPort) {\n        const port = parseInt(value, 10);\n        return port;\n      }\n\n      if (name === 'InstanceName') {\n        if (value.toUpperCase() === instanceName.toUpperCase()) {\n          getPort = true;\n        } else {\n          getPort = false;\n        }\n      }\n    }\n  }\n}\n"],"mappings":"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"}