| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204 | 'use strict'const defaults = require('./defaults')function escapeElement(elementRepresentation) {  var escaped = elementRepresentation.replace(/\\/g, '\\\\').replace(/"/g, '\\"')  return '"' + escaped + '"'}// convert a JS array to a postgres array literal// uses comma separator so won't work for types like box that use// a different array separator.function arrayString(val) {  var result = '{'  for (var i = 0; i < val.length; i++) {    if (i > 0) {      result = result + ','    }    if (val[i] === null || typeof val[i] === 'undefined') {      result = result + 'NULL'    } else if (Array.isArray(val[i])) {      result = result + arrayString(val[i])    } else if (val[i] instanceof Buffer) {      result += '\\\\x' + val[i].toString('hex')    } else {      result += escapeElement(prepareValue(val[i]))    }  }  result = result + '}'  return result}// converts values from javascript types// to their 'raw' counterparts for use as a postgres parameter// note: you can override this function to provide your own conversion mechanism// for complex types, etc...var prepareValue = function (val, seen) {  // null and undefined are both null for postgres  if (val == null) {    return null  }  if (val instanceof Buffer) {    return val  }  if (ArrayBuffer.isView(val)) {    var buf = Buffer.from(val.buffer, val.byteOffset, val.byteLength)    if (buf.length === val.byteLength) {      return buf    }    return buf.slice(val.byteOffset, val.byteOffset + val.byteLength) // Node.js v4 does not support those Buffer.from params  }  if (val instanceof Date) {    if (defaults.parseInputDatesAsUTC) {      return dateToStringUTC(val)    } else {      return dateToString(val)    }  }  if (Array.isArray(val)) {    return arrayString(val)  }  if (typeof val === 'object') {    return prepareObject(val, seen)  }  return val.toString()}function prepareObject(val, seen) {  if (val && typeof val.toPostgres === 'function') {    seen = seen || []    if (seen.indexOf(val) !== -1) {      throw new Error('circular reference detected while preparing "' + val + '" for query')    }    seen.push(val)    return prepareValue(val.toPostgres(prepareValue), seen)  }  return JSON.stringify(val)}function pad(number, digits) {  number = '' + number  while (number.length < digits) {    number = '0' + number  }  return number}function dateToString(date) {  var offset = -date.getTimezoneOffset()  var year = date.getFullYear()  var isBCYear = year < 1  if (isBCYear) year = Math.abs(year) + 1 // negative years are 1 off their BC representation  var ret =    pad(year, 4) +    '-' +    pad(date.getMonth() + 1, 2) +    '-' +    pad(date.getDate(), 2) +    'T' +    pad(date.getHours(), 2) +    ':' +    pad(date.getMinutes(), 2) +    ':' +    pad(date.getSeconds(), 2) +    '.' +    pad(date.getMilliseconds(), 3)  if (offset < 0) {    ret += '-'    offset *= -1  } else {    ret += '+'  }  ret += pad(Math.floor(offset / 60), 2) + ':' + pad(offset % 60, 2)  if (isBCYear) ret += ' BC'  return ret}function dateToStringUTC(date) {  var year = date.getUTCFullYear()  var isBCYear = year < 1  if (isBCYear) year = Math.abs(year) + 1 // negative years are 1 off their BC representation  var ret =    pad(year, 4) +    '-' +    pad(date.getUTCMonth() + 1, 2) +    '-' +    pad(date.getUTCDate(), 2) +    'T' +    pad(date.getUTCHours(), 2) +    ':' +    pad(date.getUTCMinutes(), 2) +    ':' +    pad(date.getUTCSeconds(), 2) +    '.' +    pad(date.getUTCMilliseconds(), 3)  ret += '+00:00'  if (isBCYear) ret += ' BC'  return ret}function normalizeQueryConfig(config, values, callback) {  // can take in strings or config objects  config = typeof config === 'string' ? { text: config } : config  if (values) {    if (typeof values === 'function') {      config.callback = values    } else {      config.values = values    }  }  if (callback) {    config.callback = callback  }  return config}// Ported from PostgreSQL 9.2.4 source code in src/interfaces/libpq/fe-exec.cconst escapeIdentifier = function (str) {  return '"' + str.replace(/"/g, '""') + '"'}const escapeLiteral = function (str) {  var hasBackslash = false  var escaped = "'"  for (var i = 0; i < str.length; i++) {    var c = str[i]    if (c === "'") {      escaped += c + c    } else if (c === '\\') {      escaped += c + c      hasBackslash = true    } else {      escaped += c    }  }  escaped += "'"  if (hasBackslash === true) {    escaped = ' E' + escaped  }  return escaped}module.exports = {  prepareValue: function prepareValueWrapper(value) {    // this ensures that extra arguments do not get passed into prepareValue    // by accident, eg: from calling values.map(utils.prepareValue)    return prepareValue(value)  },  normalizeQueryConfig,  escapeIdentifier,  escapeLiteral,}
 |