af-db-ts 1.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (44) hide show
  1. package/README.md +3 -0
  2. package/dist/cjs/db.js +199 -0
  3. package/dist/cjs/db.js.map +1 -0
  4. package/dist/cjs/get-value-for-sql.js +256 -0
  5. package/dist/cjs/get-value-for-sql.js.map +1 -0
  6. package/dist/cjs/index.js +20 -0
  7. package/dist/cjs/index.js.map +1 -0
  8. package/dist/cjs/interfaces.js +3 -0
  9. package/dist/cjs/interfaces.js.map +1 -0
  10. package/dist/cjs/sql.js +375 -0
  11. package/dist/cjs/sql.js.map +1 -0
  12. package/dist/cjs/utils.js +36 -0
  13. package/dist/cjs/utils.js.map +1 -0
  14. package/dist/esm/db.js +185 -0
  15. package/dist/esm/db.js.map +1 -0
  16. package/dist/esm/get-value-for-sql.js +251 -0
  17. package/dist/esm/get-value-for-sql.js.map +1 -0
  18. package/dist/esm/index.js +4 -0
  19. package/dist/esm/index.js.map +1 -0
  20. package/dist/esm/interfaces.js +2 -0
  21. package/dist/esm/interfaces.js.map +1 -0
  22. package/dist/esm/sql.js +361 -0
  23. package/dist/esm/sql.js.map +1 -0
  24. package/dist/esm/utils.js +31 -0
  25. package/dist/esm/utils.js.map +1 -0
  26. package/dist/types/db.d.ts +39 -0
  27. package/dist/types/db.d.ts.map +1 -0
  28. package/dist/types/get-value-for-sql.d.ts +7 -0
  29. package/dist/types/get-value-for-sql.d.ts.map +1 -0
  30. package/dist/types/index.d.ts +5 -0
  31. package/dist/types/index.d.ts.map +1 -0
  32. package/dist/types/interfaces.d.ts +181 -0
  33. package/dist/types/interfaces.d.ts.map +1 -0
  34. package/dist/types/sql.d.ts +56 -0
  35. package/dist/types/sql.d.ts.map +1 -0
  36. package/dist/types/utils.d.ts +10 -0
  37. package/dist/types/utils.d.ts.map +1 -0
  38. package/package.json +75 -0
  39. package/src/db.ts +195 -0
  40. package/src/get-value-for-sql.ts +271 -0
  41. package/src/index.ts +47 -0
  42. package/src/interfaces.ts +232 -0
  43. package/src/sql.ts +403 -0
  44. package/src/utils.ts +31 -0
package/README.md ADDED
@@ -0,0 +1,3 @@
1
+ ### Not of interest to third party users
2
+
3
+
package/dist/cjs/db.js ADDED
@@ -0,0 +1,199 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.query = exports.getPool = exports.logSqlError = exports.setLogger = exports.Request = exports.closeDbConnectionsAndExit = exports.closeAllDbConnections = exports.closeDbConnections = exports.getPoolConnection = exports.pools = exports.getDbConfig = exports.getFirstConfigId = void 0;
4
+ const config = require("config");
5
+ const af_color_1 = require("af-color");
6
+ const af_echo_ts_1 = require("af-echo-ts");
7
+ const sql = require("mssql");
8
+ const _ = require("lodash");
9
+ const af_tools_ts_1 = require("af-tools-ts");
10
+ const getFirstConfigId = () => Object.keys(config.get('database') || {}).filter((v) => !['dialect', '_common_'].includes(v))[0];
11
+ exports.getFirstConfigId = getFirstConfigId;
12
+ const getDbConfig = (connectionId) => config.get(`database.${connectionId}`);
13
+ exports.getDbConfig = getDbConfig;
14
+ exports.pools = {};
15
+ /**
16
+ * Возвращает пул соединений для БД, соответствующей преданному ID соединения (borf|cep|hr|global)
17
+ * В случае, если не удается создать пул или открыть соединение, прерывает работу скрипта
18
+ */
19
+ const getPoolConnection = async (connectionId, options = {}) => {
20
+ const { prefix = '', errorCode = 0 } = options;
21
+ let pool = exports.pools[connectionId];
22
+ if (pool === null || pool === void 0 ? void 0 : pool.connected) {
23
+ return pool;
24
+ }
25
+ const resume = (errMsg) => {
26
+ if (options.onError === 'exit') {
27
+ af_echo_ts_1.echo.error(prefix, `${errMsg}\nEXIT PROCESS`);
28
+ process.exit(errorCode);
29
+ }
30
+ else {
31
+ throw new Error(errMsg);
32
+ }
33
+ };
34
+ try {
35
+ const cfg = config.get('database');
36
+ const namedDbConfig = cfg[connectionId];
37
+ if (!namedDbConfig) {
38
+ resume(`Missing configuration for DB id "${connectionId}"`);
39
+ }
40
+ const dbConfig = config.util.extendDeep({}, cfg._common_ || {}, cfg[connectionId]);
41
+ if (pool === null || pool === void 0 ? void 0 : pool.connecting) {
42
+ const startTs = Date.now();
43
+ while ((pool === null || pool === void 0 ? void 0 : pool.connecting) && (Date.now() - startTs < dbConfig.connectionTimeout)) {
44
+ // eslint-disable-next-line no-await-in-loop
45
+ await (0, af_tools_ts_1.sleep)(100);
46
+ }
47
+ if (pool === null || pool === void 0 ? void 0 : pool.connected) {
48
+ return pool;
49
+ }
50
+ af_echo_ts_1.echo.error(prefix, `Can't connect connectionId "${connectionId}"`);
51
+ }
52
+ pool = new sql.ConnectionPool(dbConfig);
53
+ if (typeof pool !== 'object') {
54
+ resume(`Can't create connection pool "${connectionId}"`);
55
+ }
56
+ exports.pools[connectionId] = pool;
57
+ // @ts-ignore
58
+ pool._connectionId = connectionId;
59
+ pool.on('close', () => {
60
+ delete exports.pools[connectionId];
61
+ });
62
+ pool.on('error', (err) => {
63
+ af_echo_ts_1.echo.error('POOL-ERROR', err);
64
+ });
65
+ await pool.connect();
66
+ return pool;
67
+ }
68
+ catch (err) {
69
+ af_echo_ts_1.echo.error(err);
70
+ resume(`Cant connect to "${connectionId}" db`);
71
+ }
72
+ };
73
+ exports.getPoolConnection = getPoolConnection;
74
+ /**
75
+ * Закрывает указанные соединения с БД
76
+ *
77
+ * poolsToClose - пул или массив пулов
78
+ * prefix - Префикс в сообщении о закрытии пула (название синхронизации)
79
+ * noEcho - подавление сообщений о закрытии соединения
80
+ */
81
+ const closeDbConnections = async (poolsToClose, prefix, noEcho) => {
82
+ if (!Array.isArray(poolsToClose)) {
83
+ // @ts-ignore
84
+ poolsToClose = [poolsToClose];
85
+ }
86
+ // @ts-ignore
87
+ for (let i = 0; i < poolsToClose.length; i++) {
88
+ let pool = poolsToClose[i];
89
+ let connectionId = '';
90
+ if (pool) {
91
+ if (typeof pool === 'string') {
92
+ connectionId = pool;
93
+ pool = exports.pools[connectionId];
94
+ }
95
+ else if (typeof pool === 'object') {
96
+ // @ts-ignore
97
+ connectionId = pool._connectionId;
98
+ }
99
+ if (connectionId) {
100
+ delete exports.pools[connectionId];
101
+ }
102
+ if (pool && pool.close) {
103
+ try {
104
+ // eslint-disable-next-line no-await-in-loop
105
+ await pool.close();
106
+ if (!noEcho && connectionId) {
107
+ const msg = `pool "${connectionId}" closed`;
108
+ if (prefix) {
109
+ af_echo_ts_1.echo.info(prefix, msg);
110
+ }
111
+ else {
112
+ af_echo_ts_1.echo.info(msg);
113
+ }
114
+ }
115
+ }
116
+ catch (err) {
117
+ //
118
+ }
119
+ }
120
+ }
121
+ }
122
+ };
123
+ exports.closeDbConnections = closeDbConnections;
124
+ /**
125
+ * Закрывает все соединения с БД
126
+ *
127
+ * prefix - Префикс в сообщении о закрытии пула (название синхронизации)
128
+ * noEcho - подавление сообщений о закрытии соединения
129
+ */
130
+ const closeAllDbConnections = async (prefix, noEcho) => {
131
+ const poolsToClose = _.map(exports.pools, (p) => p);
132
+ await (0, exports.closeDbConnections)(poolsToClose, prefix, noEcho);
133
+ };
134
+ exports.closeAllDbConnections = closeAllDbConnections;
135
+ /**
136
+ * Закрывает указанные соединения с БД и прерывает работу скрипта
137
+ *
138
+ * poolsToClose - пул или массив пулов
139
+ * prefix - Префикс в сообщении о закрытии пула (название синхронизации)
140
+ */
141
+ const closeDbConnectionsAndExit = async (poolsToClose, prefix) => {
142
+ await (0, exports.closeDbConnections)(poolsToClose, prefix);
143
+ process.exit(0);
144
+ };
145
+ exports.closeDbConnectionsAndExit = closeDbConnectionsAndExit;
146
+ const Request = async (connectionId, strSQL) => {
147
+ const pool = await (0, exports.getPoolConnection)(connectionId, { onError: 'throw' });
148
+ const request = new sql.Request(pool);
149
+ if (strSQL) {
150
+ return request.query(strSQL);
151
+ }
152
+ return request;
153
+ };
154
+ exports.Request = Request;
155
+ let logger = af_echo_ts_1.echo;
156
+ const setLogger = (logger_) => {
157
+ logger = logger_;
158
+ };
159
+ exports.setLogger = setLogger;
160
+ const logSqlError = (err, noThrow, textSQL, prefix) => {
161
+ if (prefix) {
162
+ logger.error(prefix);
163
+ }
164
+ if (textSQL) {
165
+ logger.error(`SQL Error:\n${af_color_1.magenta}${textSQL}`);
166
+ }
167
+ logger.error(err);
168
+ if (!noThrow) {
169
+ throw err;
170
+ }
171
+ };
172
+ exports.logSqlError = logSqlError;
173
+ const getPool = async (dbId, noThrow = false) => {
174
+ try {
175
+ return (0, exports.getPoolConnection)(dbId);
176
+ }
177
+ catch (err) {
178
+ (0, exports.logSqlError)(err, noThrow, `Error while open connection to DB ${dbId}`);
179
+ }
180
+ };
181
+ exports.getPool = getPool;
182
+ const query = async (dbId, textSQL, noThrow, prefix) => {
183
+ const pool = await (0, exports.getPool)(dbId, noThrow);
184
+ if (!(pool === null || pool === void 0 ? void 0 : pool.connected) && !(pool === null || pool === void 0 ? void 0 : pool.connecting)) {
185
+ await (0, exports.closeDbConnections)(dbId);
186
+ return;
187
+ }
188
+ const request = new sql.Request(pool);
189
+ let res;
190
+ try {
191
+ res = await request.query(textSQL);
192
+ return res;
193
+ }
194
+ catch (err) {
195
+ (0, exports.logSqlError)(err, noThrow, textSQL, prefix);
196
+ }
197
+ };
198
+ exports.query = query;
199
+ //# sourceMappingURL=db.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"db.js","sourceRoot":"","sources":["../../src/db.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,256 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getValueForSQL = exports.binToHexString = void 0;
4
+ const luxon_1 = require("luxon");
5
+ const af_tools_ts_1 = require("af-tools-ts");
6
+ const sql_1 = require("./sql");
7
+ const utils_1 = require("./utils");
8
+ const binToHexString = (value) => (value ? `0x${value.toString(16).toUpperCase()}` : null);
9
+ exports.binToHexString = binToHexString;
10
+ const getTypeOfDateInput = (v) => {
11
+ const type = typeof v;
12
+ if (type === 'string' || type === 'number') {
13
+ return type;
14
+ }
15
+ if (type === 'boolean' || !v) {
16
+ return 'null';
17
+ }
18
+ if (type === 'object') {
19
+ if (Object.prototype.toString.call(v) === '[object Date]') {
20
+ return 'date';
21
+ }
22
+ if (v.isLuxonDateTime) {
23
+ return 'luxon';
24
+ }
25
+ if (v._isAMomentObject) {
26
+ return 'moment';
27
+ }
28
+ }
29
+ return 'any';
30
+ };
31
+ /**
32
+ * Возвращает значение, готовое для использования в строке SQL запроса
33
+ */
34
+ const getValueForSQL = (args) => {
35
+ let { value, fieldSchema, escapeOnlySingleQuotes } = args;
36
+ const { dateTimeOptions, needValidate } = args;
37
+ if (typeof fieldSchema === 'string') {
38
+ fieldSchema = { type: fieldSchema };
39
+ }
40
+ const { type, arrayType, length = 0, scale, nullable = true, inputDateFormat, defaultValue, noQuotes = false, name, } = fieldSchema;
41
+ let val;
42
+ const IS_POSTGRES = args.dialect === 'pg';
43
+ if (escapeOnlySingleQuotes == null) {
44
+ ({ escapeOnlySingleQuotes } = fieldSchema);
45
+ }
46
+ if (escapeOnlySingleQuotes == null) {
47
+ escapeOnlySingleQuotes = false;
48
+ }
49
+ function prepareNumber(min, max, value_ = value) {
50
+ if (value_ === 'null' || value_ == null || Number.isNaN(value_)) {
51
+ if (nullable) {
52
+ return 'NULL';
53
+ }
54
+ return (defaultValue || defaultValue === 0) ? `${defaultValue}` : null;
55
+ }
56
+ val = Number(value_);
57
+ if (needValidate && (val < min || val > max)) {
58
+ // throwValidateError()
59
+ throw new Error(`Type [${type}] validate error. Value: ${val} / FName: ${name}`);
60
+ }
61
+ return `${val}`;
62
+ }
63
+ const prepareSqlStringArgs = {
64
+ value, nullable, length, defaultValue, noQuotes, escapeOnlySingleQuotes,
65
+ };
66
+ switch (type) {
67
+ case 'json':
68
+ if (Array.isArray(value) || typeof value === 'object') {
69
+ value = JSON.stringify(value);
70
+ }
71
+ return (0, sql_1.prepareSqlString)({ ...prepareSqlStringArgs, value });
72
+ case 'string':
73
+ case sql_1.sql.Char:
74
+ case sql_1.sql.NChar:
75
+ case sql_1.sql.Text:
76
+ case sql_1.sql.NText:
77
+ case sql_1.sql.VarChar:
78
+ case sql_1.sql.NVarChar:
79
+ case sql_1.sql.Xml:
80
+ return (0, sql_1.prepareSqlString)(prepareSqlStringArgs);
81
+ case 'uid':
82
+ case 'uuid':
83
+ case 'uniqueIdentifier':
84
+ case sql_1.sql.UniqueIdentifier:
85
+ if (!value || typeof value !== 'string' || !/^[A-F\d]{8}(-[A-F\d]{4}){4}[A-F\d]{8}/i.test(value)) {
86
+ value = null;
87
+ }
88
+ else {
89
+ value = value.substring(0, 36).toUpperCase();
90
+ }
91
+ return (0, sql_1.prepareSqlString)({ ...prepareSqlStringArgs, value, length: 0 });
92
+ case 'datetime':
93
+ case 'date':
94
+ case 'time':
95
+ case sql_1.sql.DateTime:
96
+ case sql_1.sql.DateTime2:
97
+ case sql_1.sql.Time:
98
+ case sql_1.sql.Date:
99
+ case sql_1.sql.SmallDateTime:
100
+ case sql_1.sql.DateTimeOffset: {
101
+ let millis = 0;
102
+ val = value;
103
+ let inputType = getTypeOfDateInput(value); // 'string' | 'number' | 'date' | 'luxon' | 'moment' | 'any' | 'null'
104
+ if (inputType === 'null') {
105
+ if (nullable) {
106
+ return 'NULL';
107
+ }
108
+ inputType = 'number';
109
+ val = 0;
110
+ }
111
+ else if (inputType === 'any') {
112
+ inputType = 'string';
113
+ val = String(value);
114
+ }
115
+ switch (inputType) {
116
+ case 'number':
117
+ millis = val;
118
+ break;
119
+ case 'date':
120
+ millis = +val;
121
+ break;
122
+ case 'luxon':
123
+ millis = val.isValid ? val.toMillis() : 0;
124
+ break;
125
+ case 'moment':
126
+ millis = val.isValid() ? +val : 0;
127
+ break;
128
+ // string and other
129
+ default: {
130
+ val = String(value);
131
+ millis = (inputDateFormat
132
+ ? luxon_1.DateTime.fromFormat(val, inputDateFormat, dateTimeOptions)
133
+ : luxon_1.DateTime.fromISO(val, dateTimeOptions)).toMillis();
134
+ break;
135
+ }
136
+ }
137
+ millis = Math.max(millis + ((dateTimeOptions === null || dateTimeOptions === void 0 ? void 0 : dateTimeOptions.correctionMillis) || 0), 0);
138
+ const luxonDate = luxon_1.DateTime.fromMillis(millis);
139
+ switch (type) {
140
+ case 'datetime':
141
+ case sql_1.sql.DateTime:
142
+ case sql_1.sql.DateTime2:
143
+ return (0, utils_1.q)(luxonDate.toISO({ includeOffset: false }) || '', noQuotes); // 2023-09-05T02:23:54.105
144
+ case 'time':
145
+ case sql_1.sql.Time:
146
+ return (0, utils_1.q)((luxonDate.toISOTime() || '').substring(0, 12), noQuotes); // 02:22:17.368
147
+ case 'date':
148
+ case sql_1.sql.Date:
149
+ return (0, utils_1.q)(luxonDate.toSQLDate() || '', noQuotes); // 2023-09-05
150
+ case sql_1.sql.SmallDateTime:
151
+ return (0, utils_1.q)(`${(luxonDate.toISO() || '').substring(0, 17)}00`, noQuotes); // 2023-09-05T02:20:00
152
+ case sql_1.sql.DateTimeOffset: { // VVQ TESTS
153
+ const dotScale = scale == null ? 3 : scale;
154
+ const re = /\.(\d+)(?=[^.]*$)/;
155
+ let str = luxonDate.toISO({ includeOffset: false }) || '';
156
+ if (!dotScale) {
157
+ str = str.replace(re, `.000`);
158
+ }
159
+ else {
160
+ val = inputType === 'string' ? value : str;
161
+ let [, fracSeconds = '0'] = re.exec(val) || [];
162
+ let floatSeconds = parseFloat((`1.${fracSeconds}`));
163
+ floatSeconds = (0, af_tools_ts_1.rn)(floatSeconds, dotScale);
164
+ fracSeconds = (`${floatSeconds}0000000`).substring(2, 2 + dotScale);
165
+ str = str.replace(re, `.${fracSeconds}`);
166
+ }
167
+ return (0, utils_1.q)(str, noQuotes);
168
+ }
169
+ default:
170
+ return (0, utils_1.q)(luxonDate.toISO({ includeOffset: false }) || '', noQuotes); // 2023-09-05T02:23:54.105
171
+ }
172
+ }
173
+ case 'boolean':
174
+ case sql_1.sql.Bit: {
175
+ val = (0, af_tools_ts_1.getBool)(value);
176
+ if (IS_POSTGRES) {
177
+ return val ? 'true' : 'false';
178
+ }
179
+ return val ? '1' : '0';
180
+ }
181
+ case sql_1.sql.TinyInt:
182
+ return prepareNumber(0, 255);
183
+ case 'smallint':
184
+ case sql_1.sql.SmallInt:
185
+ return prepareNumber(-32768, 32767);
186
+ case 'int':
187
+ case sql_1.sql.Int:
188
+ case 'integer':
189
+ return prepareNumber(-2147483648, 2147483647);
190
+ case sql_1.sql.BigInt:
191
+ // eslint-disable-next-line no-loss-of-precision
192
+ return prepareNumber(-9223372036854775808, 9223372036854775807);
193
+ case 'number':
194
+ case sql_1.sql.Decimal:
195
+ case sql_1.sql.Float:
196
+ case sql_1.sql.Money:
197
+ case sql_1.sql.Numeric:
198
+ case sql_1.sql.SmallMoney:
199
+ case sql_1.sql.Real:
200
+ if (value == null) {
201
+ if (nullable) {
202
+ return 'NULL';
203
+ }
204
+ return (defaultValue || defaultValue === 0) ? `${defaultValue}` : null;
205
+ }
206
+ return `${value}`;
207
+ case sql_1.sql.Binary:
208
+ case sql_1.sql.VarBinary:
209
+ case sql_1.sql.Image:
210
+ if (value == null) {
211
+ if (nullable) {
212
+ return 'NULL';
213
+ }
214
+ if (!defaultValue)
215
+ return null;
216
+ }
217
+ return (0, exports.binToHexString)(value);
218
+ case sql_1.sql.UDT:
219
+ case sql_1.sql.Geography:
220
+ case sql_1.sql.Geometry:
221
+ case sql_1.sql.Variant:
222
+ return (0, sql_1.prepareSqlString)(prepareSqlStringArgs);
223
+ case 'array': {
224
+ let arr = [];
225
+ if (Array.isArray(value) && value.length) {
226
+ switch (arrayType) {
227
+ case 'int':
228
+ case 'integer':
229
+ arr = value.map((v) => prepareNumber(-2147483648, 2147483647, v));
230
+ break;
231
+ default: // + case 'string'
232
+ arr = value.map((v) => {
233
+ if (v === '') {
234
+ return v;
235
+ }
236
+ if (v == null) {
237
+ return null;
238
+ }
239
+ return (0, utils_1.mssqlEscape)(String(value));
240
+ })
241
+ .filter((v) => v != null)
242
+ .map((v) => `"${v}"`);
243
+ break;
244
+ }
245
+ }
246
+ if (arr.length) {
247
+ return `{${arr.join(',')}`;
248
+ }
249
+ return '{}';
250
+ }
251
+ default:
252
+ return (0, sql_1.prepareSqlString)(prepareSqlStringArgs);
253
+ }
254
+ };
255
+ exports.getValueForSQL = getValueForSQL;
256
+ //# sourceMappingURL=get-value-for-sql.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-value-for-sql.js","sourceRoot":"","sources":["../../src/get-value-for-sql.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getValueForSQL = exports.binToHexString = exports.getRowsAffected = exports.prepareDataForSQL = exports.prepareRecordForSQL = exports.getSqlValuesExpression = exports.getSqlSetExpression = exports.getRecordValuesForSQL = exports.serialize = exports.wrapTransaction = exports.getRecordSchema = exports.correctRecordSchema = exports.prepareSqlString = exports.db = void 0;
4
+ exports.db = require("./db");
5
+ var sql_1 = require("./sql");
6
+ Object.defineProperty(exports, "prepareSqlString", { enumerable: true, get: function () { return sql_1.prepareSqlString; } });
7
+ Object.defineProperty(exports, "correctRecordSchema", { enumerable: true, get: function () { return sql_1.correctRecordSchema; } });
8
+ Object.defineProperty(exports, "getRecordSchema", { enumerable: true, get: function () { return sql_1.getRecordSchema; } });
9
+ Object.defineProperty(exports, "wrapTransaction", { enumerable: true, get: function () { return sql_1.wrapTransaction; } });
10
+ Object.defineProperty(exports, "serialize", { enumerable: true, get: function () { return sql_1.serialize; } });
11
+ Object.defineProperty(exports, "getRecordValuesForSQL", { enumerable: true, get: function () { return sql_1.getRecordValuesForSQL; } });
12
+ Object.defineProperty(exports, "getSqlSetExpression", { enumerable: true, get: function () { return sql_1.getSqlSetExpression; } });
13
+ Object.defineProperty(exports, "getSqlValuesExpression", { enumerable: true, get: function () { return sql_1.getSqlValuesExpression; } });
14
+ Object.defineProperty(exports, "prepareRecordForSQL", { enumerable: true, get: function () { return sql_1.prepareRecordForSQL; } });
15
+ Object.defineProperty(exports, "prepareDataForSQL", { enumerable: true, get: function () { return sql_1.prepareDataForSQL; } });
16
+ Object.defineProperty(exports, "getRowsAffected", { enumerable: true, get: function () { return sql_1.getRowsAffected; } });
17
+ var get_value_for_sql_1 = require("./get-value-for-sql");
18
+ Object.defineProperty(exports, "binToHexString", { enumerable: true, get: function () { return get_value_for_sql_1.binToHexString; } });
19
+ Object.defineProperty(exports, "getValueForSQL", { enumerable: true, get: function () { return get_value_for_sql_1.getValueForSQL; } });
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;AAAA,6BAA2B;AAE3B,6BAYe;AAXb,uGAAA,gBAAgB,OAAA;AAChB,0GAAA,mBAAmB,OAAA;AACnB,sGAAA,eAAe,OAAA;AACf,sGAAA,eAAe,OAAA;AACf,gGAAA,SAAS,OAAA;AACT,4GAAA,qBAAqB,OAAA;AACrB,0GAAA,mBAAmB,OAAA;AACnB,6GAAA,sBAAsB,OAAA;AACtB,0GAAA,mBAAmB,OAAA;AACnB,wGAAA,iBAAiB,OAAA;AACjB,sGAAA,eAAe,OAAA;AAGjB,yDAG6B;AAF3B,mHAAA,cAAc,OAAA;AACd,mHAAA,cAAc,OAAA"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=interfaces.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../src/interfaces.ts"],"names":[],"mappings":""}