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.
- package/README.md +3 -0
- package/dist/cjs/db.js +199 -0
- package/dist/cjs/db.js.map +1 -0
- package/dist/cjs/get-value-for-sql.js +256 -0
- package/dist/cjs/get-value-for-sql.js.map +1 -0
- package/dist/cjs/index.js +20 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/interfaces.js +3 -0
- package/dist/cjs/interfaces.js.map +1 -0
- package/dist/cjs/sql.js +375 -0
- package/dist/cjs/sql.js.map +1 -0
- package/dist/cjs/utils.js +36 -0
- package/dist/cjs/utils.js.map +1 -0
- package/dist/esm/db.js +185 -0
- package/dist/esm/db.js.map +1 -0
- package/dist/esm/get-value-for-sql.js +251 -0
- package/dist/esm/get-value-for-sql.js.map +1 -0
- package/dist/esm/index.js +4 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/interfaces.js +2 -0
- package/dist/esm/interfaces.js.map +1 -0
- package/dist/esm/sql.js +361 -0
- package/dist/esm/sql.js.map +1 -0
- package/dist/esm/utils.js +31 -0
- package/dist/esm/utils.js.map +1 -0
- package/dist/types/db.d.ts +39 -0
- package/dist/types/db.d.ts.map +1 -0
- package/dist/types/get-value-for-sql.d.ts +7 -0
- package/dist/types/get-value-for-sql.d.ts.map +1 -0
- package/dist/types/index.d.ts +5 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/interfaces.d.ts +181 -0
- package/dist/types/interfaces.d.ts.map +1 -0
- package/dist/types/sql.d.ts +56 -0
- package/dist/types/sql.d.ts.map +1 -0
- package/dist/types/utils.d.ts +10 -0
- package/dist/types/utils.d.ts.map +1 -0
- package/package.json +75 -0
- package/src/db.ts +195 -0
- package/src/get-value-for-sql.ts +271 -0
- package/src/index.ts +47 -0
- package/src/interfaces.ts +232 -0
- package/src/sql.ts +403 -0
- package/src/utils.ts +31 -0
package/README.md
ADDED
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 @@
|
|
|
1
|
+
{"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../src/interfaces.ts"],"names":[],"mappings":""}
|