taon-type-sql 18.0.26 → 19.0.1

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 (151) hide show
  1. package/assets/shared/shared_folder_info.txt +3 -3
  2. package/browser/README.md +24 -24
  3. package/client/README.md +24 -24
  4. package/index.js.map +1 -1
  5. package/lib/build-info._auto-generated_.d.ts +1 -0
  6. package/lib/build-info._auto-generated_.js +4 -1
  7. package/lib/build-info._auto-generated_.js.map +1 -1
  8. package/lib/builder/column/basic-column.js.map +1 -1
  9. package/lib/builder/column/boolean-column.js.map +1 -1
  10. package/lib/builder/column/comparable-column.js.map +1 -1
  11. package/lib/builder/column/date-column.js.map +1 -1
  12. package/lib/builder/column/number-column.js.map +1 -1
  13. package/lib/builder/column/query-column.js.map +1 -1
  14. package/lib/builder/column/string-column.js.map +1 -1
  15. package/lib/builder/column/value-column.js.map +1 -1
  16. package/lib/builder/condition/query-column-condition.js.map +1 -1
  17. package/lib/builder/condition/query-condition-chain.js.map +1 -1
  18. package/lib/builder/condition/query-condition.js.map +1 -1
  19. package/lib/builder/condition/query-join-condition.js.map +1 -1
  20. package/lib/builder/helpers/generics-helper.js.map +1 -1
  21. package/lib/builder/helpers/internal-types.js.map +1 -1
  22. package/lib/builder/join/joined-tables-chain.js.map +1 -1
  23. package/lib/builder/join/joined-tables.js.map +1 -1
  24. package/lib/builder/other/query-ordering.js.map +1 -1
  25. package/lib/builder/query/select-query.js.map +1 -1
  26. package/lib/builder/query/table-condition-query.js.map +1 -1
  27. package/lib/builder/query/table-query.js.map +1 -1
  28. package/lib/builder/query-source.js.map +1 -1
  29. package/lib/builder/query-table.js.map +1 -1
  30. package/lib/client/mysql.js.map +1 -1
  31. package/lib/client/pg.js.map +1 -1
  32. package/lib/client/query-processor.js.map +1 -1
  33. package/lib/converter/param-converter.js.map +1 -1
  34. package/lib/converter/parameterized-converter.js.map +1 -1
  35. package/lib/converter/query-converter.js.map +1 -1
  36. package/lib/converter/result-converter.js.map +1 -1
  37. package/lib/converter/sql-converter.js.map +1 -1
  38. package/lib/converter/type-converter.js.map +1 -1
  39. package/lib/converter/types.js.map +1 -1
  40. package/lib/index._auto-generated_.js +2 -2
  41. package/lib/index._auto-generated_.js.map +1 -1
  42. package/lib/index.js.map +1 -1
  43. package/migrations/index.js.map +1 -1
  44. package/migrations/migrations_index._auto-generated_.js.map +1 -1
  45. package/package.json +2 -2
  46. package/src.d.ts +3 -3
  47. package/taon.jsonc +12 -12
  48. package/tmp-environment.json +4 -3
  49. package/websql/README.md +24 -24
  50. package/browser/esm2022/lib/builder/column/basic-column.mjs +0 -13
  51. package/browser/esm2022/lib/builder/column/boolean-column.mjs +0 -14
  52. package/browser/esm2022/lib/builder/column/comparable-column.mjs +0 -41
  53. package/browser/esm2022/lib/builder/column/date-column.mjs +0 -14
  54. package/browser/esm2022/lib/builder/column/number-column.mjs +0 -19
  55. package/browser/esm2022/lib/builder/column/query-column.mjs +0 -21
  56. package/browser/esm2022/lib/builder/column/string-column.mjs +0 -36
  57. package/browser/esm2022/lib/builder/column/value-column.mjs +0 -30
  58. package/browser/esm2022/lib/builder/condition/query-column-condition.mjs +0 -19
  59. package/browser/esm2022/lib/builder/condition/query-condition-chain.mjs +0 -28
  60. package/browser/esm2022/lib/builder/condition/query-condition.mjs +0 -6
  61. package/browser/esm2022/lib/builder/condition/query-join-condition.mjs +0 -19
  62. package/browser/esm2022/lib/builder/helpers/generics-helper.mjs +0 -5
  63. package/browser/esm2022/lib/builder/helpers/internal-types.mjs +0 -4
  64. package/browser/esm2022/lib/builder/join/joined-tables-chain.mjs +0 -14
  65. package/browser/esm2022/lib/builder/join/joined-tables.mjs +0 -22
  66. package/browser/esm2022/lib/builder/other/query-ordering.mjs +0 -17
  67. package/browser/esm2022/lib/builder/query/select-query.mjs +0 -48
  68. package/browser/esm2022/lib/builder/query/table-condition-query.mjs +0 -25
  69. package/browser/esm2022/lib/builder/query/table-query.mjs +0 -54
  70. package/browser/esm2022/lib/builder/query-source.mjs +0 -20
  71. package/browser/esm2022/lib/builder/query-table.mjs +0 -24
  72. package/browser/esm2022/lib/client/mysql.mjs +0 -10
  73. package/browser/esm2022/lib/client/query-processor.mjs +0 -45
  74. package/browser/esm2022/lib/converter/param-converter.mjs +0 -27
  75. package/browser/esm2022/lib/converter/parameterized-converter.mjs +0 -17
  76. package/browser/esm2022/lib/converter/query-converter.mjs +0 -282
  77. package/browser/esm2022/lib/converter/result-converter.mjs +0 -88
  78. package/browser/esm2022/lib/converter/sql-converter.mjs +0 -8
  79. package/browser/esm2022/lib/converter/type-converter.mjs +0 -39
  80. package/browser/esm2022/lib/converter/types.mjs +0 -4
  81. package/browser/esm2022/lib/index.mjs +0 -23
  82. package/browser/esm2022/public-api.mjs +0 -2
  83. package/browser/esm2022/taon-type-sql.mjs +0 -5
  84. package/client/esm2022/lib/builder/column/basic-column.mjs +0 -13
  85. package/client/esm2022/lib/builder/column/boolean-column.mjs +0 -14
  86. package/client/esm2022/lib/builder/column/comparable-column.mjs +0 -41
  87. package/client/esm2022/lib/builder/column/date-column.mjs +0 -14
  88. package/client/esm2022/lib/builder/column/number-column.mjs +0 -19
  89. package/client/esm2022/lib/builder/column/query-column.mjs +0 -21
  90. package/client/esm2022/lib/builder/column/string-column.mjs +0 -36
  91. package/client/esm2022/lib/builder/column/value-column.mjs +0 -30
  92. package/client/esm2022/lib/builder/condition/query-column-condition.mjs +0 -19
  93. package/client/esm2022/lib/builder/condition/query-condition-chain.mjs +0 -28
  94. package/client/esm2022/lib/builder/condition/query-condition.mjs +0 -6
  95. package/client/esm2022/lib/builder/condition/query-join-condition.mjs +0 -19
  96. package/client/esm2022/lib/builder/helpers/generics-helper.mjs +0 -5
  97. package/client/esm2022/lib/builder/helpers/internal-types.mjs +0 -4
  98. package/client/esm2022/lib/builder/join/joined-tables-chain.mjs +0 -14
  99. package/client/esm2022/lib/builder/join/joined-tables.mjs +0 -22
  100. package/client/esm2022/lib/builder/other/query-ordering.mjs +0 -17
  101. package/client/esm2022/lib/builder/query/select-query.mjs +0 -48
  102. package/client/esm2022/lib/builder/query/table-condition-query.mjs +0 -25
  103. package/client/esm2022/lib/builder/query/table-query.mjs +0 -54
  104. package/client/esm2022/lib/builder/query-source.mjs +0 -20
  105. package/client/esm2022/lib/builder/query-table.mjs +0 -24
  106. package/client/esm2022/lib/client/mysql.mjs +0 -10
  107. package/client/esm2022/lib/client/query-processor.mjs +0 -45
  108. package/client/esm2022/lib/converter/param-converter.mjs +0 -27
  109. package/client/esm2022/lib/converter/parameterized-converter.mjs +0 -17
  110. package/client/esm2022/lib/converter/query-converter.mjs +0 -282
  111. package/client/esm2022/lib/converter/result-converter.mjs +0 -88
  112. package/client/esm2022/lib/converter/sql-converter.mjs +0 -8
  113. package/client/esm2022/lib/converter/type-converter.mjs +0 -39
  114. package/client/esm2022/lib/converter/types.mjs +0 -4
  115. package/client/esm2022/lib/index.mjs +0 -23
  116. package/client/esm2022/public-api.mjs +0 -2
  117. package/client/esm2022/taon-type-sql.mjs +0 -5
  118. package/websql/esm2022/lib/builder/column/basic-column.mjs +0 -13
  119. package/websql/esm2022/lib/builder/column/boolean-column.mjs +0 -14
  120. package/websql/esm2022/lib/builder/column/comparable-column.mjs +0 -41
  121. package/websql/esm2022/lib/builder/column/date-column.mjs +0 -14
  122. package/websql/esm2022/lib/builder/column/number-column.mjs +0 -19
  123. package/websql/esm2022/lib/builder/column/query-column.mjs +0 -21
  124. package/websql/esm2022/lib/builder/column/string-column.mjs +0 -36
  125. package/websql/esm2022/lib/builder/column/value-column.mjs +0 -30
  126. package/websql/esm2022/lib/builder/condition/query-column-condition.mjs +0 -19
  127. package/websql/esm2022/lib/builder/condition/query-condition-chain.mjs +0 -28
  128. package/websql/esm2022/lib/builder/condition/query-condition.mjs +0 -6
  129. package/websql/esm2022/lib/builder/condition/query-join-condition.mjs +0 -19
  130. package/websql/esm2022/lib/builder/helpers/generics-helper.mjs +0 -5
  131. package/websql/esm2022/lib/builder/helpers/internal-types.mjs +0 -4
  132. package/websql/esm2022/lib/builder/join/joined-tables-chain.mjs +0 -14
  133. package/websql/esm2022/lib/builder/join/joined-tables.mjs +0 -22
  134. package/websql/esm2022/lib/builder/other/query-ordering.mjs +0 -17
  135. package/websql/esm2022/lib/builder/query/select-query.mjs +0 -48
  136. package/websql/esm2022/lib/builder/query/table-condition-query.mjs +0 -25
  137. package/websql/esm2022/lib/builder/query/table-query.mjs +0 -54
  138. package/websql/esm2022/lib/builder/query-source.mjs +0 -20
  139. package/websql/esm2022/lib/builder/query-table.mjs +0 -24
  140. package/websql/esm2022/lib/client/mysql.mjs +0 -10
  141. package/websql/esm2022/lib/client/query-processor.mjs +0 -45
  142. package/websql/esm2022/lib/converter/param-converter.mjs +0 -27
  143. package/websql/esm2022/lib/converter/parameterized-converter.mjs +0 -17
  144. package/websql/esm2022/lib/converter/query-converter.mjs +0 -282
  145. package/websql/esm2022/lib/converter/result-converter.mjs +0 -88
  146. package/websql/esm2022/lib/converter/sql-converter.mjs +0 -8
  147. package/websql/esm2022/lib/converter/type-converter.mjs +0 -39
  148. package/websql/esm2022/lib/converter/types.mjs +0 -4
  149. package/websql/esm2022/lib/index.mjs +0 -23
  150. package/websql/esm2022/public-api.mjs +0 -2
  151. package/websql/esm2022/taon-type-sql.mjs +0 -5
@@ -1,45 +0,0 @@
1
- import { Log } from 'ng2-logger/websql';
2
- import { convertQueryToParameterizedSQL } from '../converter/parameterized-converter';
3
- import { convertQueryToSQL } from '../converter/sql-converter';
4
- const log = Log.create('query processor');
5
- const DEFAULT_OPTIONS = {
6
- lineBreaks: false,
7
- parameterized: true,
8
- logging: true,
9
- identifierQuote: '"'
10
- };
11
- function mySqlTypeCast(field, next) {
12
- if (field.type == 'TINY' && field.length == 1) { // Boolean
13
- let value = field.string();
14
- if (value == '1')
15
- return true;
16
- if (value == '0')
17
- return false;
18
- return null;
19
- }
20
- else if (field.type == 'JSON') {
21
- let value = field.string();
22
- return value == null ? null : JSON.parse(value);
23
- }
24
- return next();
25
- }
26
- export function createQueryProcessor(client, _options = {}, engine = 'pg') {
27
- let options = Object.assign({}, DEFAULT_OPTIONS, _options);
28
- let queryOptions = {
29
- lineBreak: options.lineBreaks ? '\n' : ' ',
30
- nameEscape: _options.identifierQuote || (engine === 'mysql' ? '`' : '"')
31
- };
32
- return (query) => {
33
- if (options.parameterized) {
34
- let { sql, params } = convertQueryToParameterizedSQL(query, queryOptions, engine);
35
- return client.query(sql, params);
36
- }
37
- else {
38
- let sql = convertQueryToSQL(query, queryOptions, engine);
39
- return client.query(sql, undefined);
40
- }
41
- };
42
- }
43
- ;
44
- ({}); // @--end-of-file-for-module=taon-type-sql lib/client/query-processor.ts
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcnktcHJvY2Vzc29yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vdG1wLWxpYnMtZm9yLWRpc3Qtd2Vic3FsL3Rhb24tdHlwZS1zcWwvcHJvamVjdHMvdGFvbi10eXBlLXNxbC9zcmMvbGliL2NsaWVudC9xdWVyeS1wcm9jZXNzb3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLEdBQUcsRUFBUyxNQUFNLG1CQUFtQixDQUFDO0FBQy9DLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBTS9ELE1BQU0sR0FBRyxHQUFHLEdBQUcsQ0FBQyxNQUFNLENBQUMsaUJBQWlCLENBRXZDLENBQUE7QUFVRCxNQUFNLGVBQWUsR0FBMEI7SUFDN0MsVUFBVSxFQUFFLEtBQUs7SUFDakIsYUFBYSxFQUFFLElBQUk7SUFDbkIsT0FBTyxFQUFFLElBQUk7SUFDYixlQUFlLEVBQUUsR0FBRztDQUNyQixDQUFDO0FBRUYsU0FBUyxhQUFhLENBQUMsS0FBVSxFQUFFLElBQVM7SUFDMUMsSUFBSSxLQUFLLENBQUMsSUFBSSxJQUFJLE1BQU0sSUFBSSxLQUFLLENBQUMsTUFBTSxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsVUFBVTtRQUN6RCxJQUFJLEtBQUssR0FBRyxLQUFLLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDM0IsSUFBSSxLQUFLLElBQUksR0FBRztZQUFFLE9BQU8sSUFBSSxDQUFDO1FBQzlCLElBQUksS0FBSyxJQUFJLEdBQUc7WUFBRSxPQUFPLEtBQUssQ0FBQztRQUMvQixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7U0FBTSxJQUFJLEtBQUssQ0FBQyxJQUFJLElBQUksTUFBTSxFQUFFLENBQUM7UUFDaEMsSUFBSSxLQUFLLEdBQUcsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQzNCLE9BQU8sS0FBSyxJQUFJLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2xELENBQUM7SUFDRCxPQUFPLElBQUksRUFBRSxDQUFDO0FBQ2hCLENBQUM7QUFFRCxNQUFNLFVBQVUsb0JBQW9CLENBQUMsTUFBVyxFQUFFLFdBQWtDLEVBQUUsRUFBRSxTQUFzQixJQUFJO0lBRWhILElBQUksT0FBTyxHQUEwQixNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxlQUFlLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFFbEYsSUFBSSxZQUFZLEdBQXFCO1FBQ25DLFNBQVMsRUFBRSxPQUFPLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEdBQUc7UUFDMUMsVUFBVSxFQUFFLFFBQVEsQ0FBQyxlQUFlLElBQUksQ0FBQyxNQUFNLEtBQUssT0FBTyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQztLQUN6RSxDQUFDO0lBMEJGLE9BQU8sQ0FBQyxLQUFVLEVBQUUsRUFBRTtRQUNwQixJQUFJLE9BQU8sQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUMxQixJQUFJLEVBQUUsR0FBRyxFQUFFLE1BQU0sRUFBRSxHQUFHLDhCQUE4QixDQUFDLEtBQUssRUFBRSxZQUFZLEVBQUUsTUFBTSxDQUFDLENBQUM7WUFFbEYsT0FBTyxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRSxNQUFNLENBQUMsQ0FBQztRQUduQyxDQUFDO2FBQU0sQ0FBQztZQUNOLElBQUksR0FBRyxHQUFHLGlCQUFpQixDQUFDLEtBQUssRUFBRSxZQUFZLEVBQUUsTUFBTSxDQUFDLENBQUM7WUFFekQsT0FBTyxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUd0QyxDQUFDO0lBQ0gsQ0FBQyxDQUFDO0FBQ0osQ0FBQztBQUdBLENBQUM7QUFBQSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsd0VBQXdFIiwic291cmNlc0NvbnRlbnQiOlsiXG5cbmltcG9ydCB7IExvZywgTGV2ZWwgfSBmcm9tICduZzItbG9nZ2VyL3dlYnNxbCc7XG5pbXBvcnQgeyBjb252ZXJ0UXVlcnlUb1BhcmFtZXRlcml6ZWRTUUwgfSBmcm9tICcuLi9jb252ZXJ0ZXIvcGFyYW1ldGVyaXplZC1jb252ZXJ0ZXInO1xuaW1wb3J0IHsgY29udmVydFF1ZXJ5VG9TUUwgfSBmcm9tICcuLi9jb252ZXJ0ZXIvc3FsLWNvbnZlcnRlcic7XG5pbXBvcnQgeyBjb252ZXJ0UmVzdWx0IH0gZnJvbSBcIi4uL2NvbnZlcnRlci9yZXN1bHQtY29udmVydGVyXCI7XG5pbXBvcnQgeyBRdWVyeUVuZ2luZSwgQ29udmVydGVyT3B0aW9ucyB9IGZyb20gJy4uL2NvbnZlcnRlci90eXBlcyc7XG5pbXBvcnQgeyBRdWVyeVByb2Nlc3NvciB9IGZyb20gJy4uL2J1aWxkZXIvaGVscGVycy9pbnRlcm5hbC10eXBlcyc7XG5pbXBvcnQgeyBIZWxwZXJzIH0gZnJvbSAndG5wLWNvcmUvd2Vic3FsJztcblxuY29uc3QgbG9nID0gTG9nLmNyZWF0ZSgncXVlcnkgcHJvY2Vzc29yJyxcblxuKVxuXG5leHBvcnQgaW50ZXJmYWNlIFF1ZXJ5UHJvY2Vzc29yT3B0aW9ucyB7XG4gIGxpbmVCcmVha3M/OiBib29sZWFuLFxuICBwYXJhbWV0ZXJpemVkPzogYm9vbGVhbixcbiAgbG9nZ2luZz86IGJvb2xlYW4sXG4gIGxvZ2dlcj86IChzcWw6IHN0cmluZywgcGFyYW1zPzogYW55W10pID0+IHZvaWQsXG4gIGlkZW50aWZpZXJRdW90ZT86IHN0cmluZ1xufVxuXG5jb25zdCBERUZBVUxUX09QVElPTlM6IFF1ZXJ5UHJvY2Vzc29yT3B0aW9ucyA9IHtcbiAgbGluZUJyZWFrczogZmFsc2UsXG4gIHBhcmFtZXRlcml6ZWQ6IHRydWUsXG4gIGxvZ2dpbmc6IHRydWUsXG4gIGlkZW50aWZpZXJRdW90ZTogJ1wiJ1xufTtcblxuZnVuY3Rpb24gbXlTcWxUeXBlQ2FzdChmaWVsZDogYW55LCBuZXh0OiBhbnkpIHtcbiAgaWYgKGZpZWxkLnR5cGUgPT0gJ1RJTlknICYmIGZpZWxkLmxlbmd0aCA9PSAxKSB7IC8vIEJvb2xlYW5cbiAgICBsZXQgdmFsdWUgPSBmaWVsZC5zdHJpbmcoKTtcbiAgICBpZiAodmFsdWUgPT0gJzEnKSByZXR1cm4gdHJ1ZTtcbiAgICBpZiAodmFsdWUgPT0gJzAnKSByZXR1cm4gZmFsc2U7XG4gICAgcmV0dXJuIG51bGw7XG4gIH0gZWxzZSBpZiAoZmllbGQudHlwZSA9PSAnSlNPTicpIHtcbiAgICBsZXQgdmFsdWUgPSBmaWVsZC5zdHJpbmcoKTtcbiAgICByZXR1cm4gdmFsdWUgPT0gbnVsbCA/IG51bGwgOiBKU09OLnBhcnNlKHZhbHVlKTtcbiAgfVxuICByZXR1cm4gbmV4dCgpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlUXVlcnlQcm9jZXNzb3IoY2xpZW50OiBhbnksIF9vcHRpb25zOiBRdWVyeVByb2Nlc3Nvck9wdGlvbnMgPSB7fSwgZW5naW5lOiBRdWVyeUVuZ2luZSA9ICdwZycpOiBRdWVyeVByb2Nlc3NvciB7XG5cbiAgbGV0IG9wdGlvbnM6IFF1ZXJ5UHJvY2Vzc29yT3B0aW9ucyA9IE9iamVjdC5hc3NpZ24oe30sIERFRkFVTFRfT1BUSU9OUywgX29wdGlvbnMpO1xuXG4gIGxldCBxdWVyeU9wdGlvbnM6IENvbnZlcnRlck9wdGlvbnMgPSB7XG4gICAgbGluZUJyZWFrOiBvcHRpb25zLmxpbmVCcmVha3MgPyAnXFxuJyA6ICcgJyxcbiAgICBuYW1lRXNjYXBlOiBfb3B0aW9ucy5pZGVudGlmaWVyUXVvdGUgfHwgKGVuZ2luZSA9PT0gJ215c3FsJyA/ICdgJyA6ICdcIicpXG4gIH07XG5cblxuXG5cblxuXG5cblxuXG5cblxuXG5cblxuXG5cblxuXG5cblxuXG5cblxuXG5cbiAgcmV0dXJuIChxdWVyeTogYW55KSA9PiB7XG4gICAgaWYgKG9wdGlvbnMucGFyYW1ldGVyaXplZCkge1xuICAgICAgbGV0IHsgc3FsLCBwYXJhbXMgfSA9IGNvbnZlcnRRdWVyeVRvUGFyYW1ldGVyaXplZFNRTChxdWVyeSwgcXVlcnlPcHRpb25zLCBlbmdpbmUpO1xuXG4gICAgICByZXR1cm4gY2xpZW50LnF1ZXJ5KHNxbCwgcGFyYW1zKTtcblxuXG4gICAgfSBlbHNlIHtcbiAgICAgIGxldCBzcWwgPSBjb252ZXJ0UXVlcnlUb1NRTChxdWVyeSwgcXVlcnlPcHRpb25zLCBlbmdpbmUpO1xuXG4gICAgICByZXR1cm4gY2xpZW50LnF1ZXJ5KHNxbCwgdW5kZWZpbmVkKTtcblxuXG4gICAgfVxuICB9O1xufVxuXG5cbiA7KHt9KTsgLy8gQC0tZW5kLW9mLWZpbGUtZm9yLW1vZHVsZT10YW9uLXR5cGUtc3FsIGxpYi9jbGllbnQvcXVlcnktcHJvY2Vzc29yLnRzIl19
@@ -1,27 +0,0 @@
1
- export function convertSubstitutionParam(param) {
2
- if (param == null)
3
- return 'NULL';
4
- if (typeof param === 'string' || param instanceof String) {
5
- return `'${String(param)}'`;
6
- }
7
- else if (typeof param === 'boolean' || param instanceof Boolean) {
8
- return String(param).toUpperCase();
9
- }
10
- else if (param instanceof Date) {
11
- return `'${param.toISOString()}'`;
12
- }
13
- else if (typeof param === 'number' || param instanceof Number) {
14
- return String(param);
15
- }
16
- return `'${JSON.stringify(param)}'`;
17
- }
18
- export function convertEscapedParam(param) {
19
- if (typeof param === 'object' && !(param == null || param instanceof String || param instanceof Number ||
20
- param instanceof Boolean || param instanceof Date)) {
21
- return JSON.stringify(param);
22
- }
23
- return param;
24
- }
25
- ;
26
- ({}); // @--end-of-file-for-module=taon-type-sql lib/converter/param-converter.ts
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyYW0tY29udmVydGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vdG1wLWxpYnMtZm9yLWRpc3Qtd2Vic3FsL3Rhb24tdHlwZS1zcWwvcHJvamVjdHMvdGFvbi10eXBlLXNxbC9zcmMvbGliL2NvbnZlcnRlci9wYXJhbS1jb252ZXJ0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsTUFBTSxVQUFVLHdCQUF3QixDQUFDLEtBQVU7SUFDL0MsSUFBSSxLQUFLLElBQUksSUFBSTtRQUFFLE9BQU8sTUFBTSxDQUFDO0lBQ2pDLElBQUksT0FBTyxLQUFLLEtBQUssUUFBUSxJQUFJLEtBQUssWUFBWSxNQUFNLEVBQUUsQ0FBQztRQUN2RCxPQUFPLElBQUksTUFBTSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUM7SUFDaEMsQ0FBQztTQUFNLElBQUksT0FBTyxLQUFLLEtBQUssU0FBUyxJQUFJLEtBQUssWUFBWSxPQUFPLEVBQUUsQ0FBQztRQUNoRSxPQUFPLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUN2QyxDQUFDO1NBQU0sSUFBSSxLQUFLLFlBQVksSUFBSSxFQUFFLENBQUM7UUFDL0IsT0FBTyxJQUFJLEtBQUssQ0FBQyxXQUFXLEVBQUUsR0FBRyxDQUFDO0lBQ3RDLENBQUM7U0FBTSxJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsSUFBSSxLQUFLLFlBQVksTUFBTSxFQUFFLENBQUM7UUFDOUQsT0FBTyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDekIsQ0FBQztJQUNELE9BQU8sSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUM7QUFDeEMsQ0FBQztBQUlELE1BQU0sVUFBVSxtQkFBbUIsQ0FBQyxLQUFVO0lBQzFDLElBQUksT0FBTyxLQUFLLEtBQUssUUFBUSxJQUFJLENBQUMsQ0FBQyxLQUFLLElBQUksSUFBSSxJQUFJLEtBQUssWUFBWSxNQUFNLElBQUksS0FBSyxZQUFZLE1BQU07UUFDbEcsS0FBSyxZQUFZLE9BQU8sSUFBSSxLQUFLLFlBQVksSUFBSSxDQUFDLEVBQUUsQ0FBQztRQUNyRCxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUNELE9BQU8sS0FBSyxDQUFDO0FBQ2pCLENBQUM7QUFFQSxDQUFDO0FBQUEsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLDJFQUEyRSIsInNvdXJjZXNDb250ZW50IjpbIlxuXG5cbmV4cG9ydCBmdW5jdGlvbiBjb252ZXJ0U3Vic3RpdHV0aW9uUGFyYW0ocGFyYW06IGFueSk6IHN0cmluZyB7XG4gICAgaWYgKHBhcmFtID09IG51bGwpIHJldHVybiAnTlVMTCc7XG4gICAgaWYgKHR5cGVvZiBwYXJhbSA9PT0gJ3N0cmluZycgfHwgcGFyYW0gaW5zdGFuY2VvZiBTdHJpbmcpIHtcbiAgICAgICAgcmV0dXJuIGAnJHtTdHJpbmcocGFyYW0pfSdgO1xuICAgIH0gZWxzZSBpZiAodHlwZW9mIHBhcmFtID09PSAnYm9vbGVhbicgfHwgcGFyYW0gaW5zdGFuY2VvZiBCb29sZWFuKSB7XG4gICAgICAgIHJldHVybiBTdHJpbmcocGFyYW0pLnRvVXBwZXJDYXNlKCk7XG4gICAgfSBlbHNlIGlmIChwYXJhbSBpbnN0YW5jZW9mIERhdGUpIHtcbiAgICAgICAgcmV0dXJuIGAnJHtwYXJhbS50b0lTT1N0cmluZygpfSdgO1xuICAgIH0gZWxzZSBpZiAodHlwZW9mIHBhcmFtID09PSAnbnVtYmVyJyB8fCBwYXJhbSBpbnN0YW5jZW9mIE51bWJlcikge1xuICAgICAgICByZXR1cm4gU3RyaW5nKHBhcmFtKTtcbiAgICB9XG4gICAgcmV0dXJuIGAnJHtKU09OLnN0cmluZ2lmeShwYXJhbSl9J2A7XG59XG5cblxuXG5leHBvcnQgZnVuY3Rpb24gY29udmVydEVzY2FwZWRQYXJhbShwYXJhbTogYW55KSB7XG4gICAgaWYgKHR5cGVvZiBwYXJhbSA9PT0gJ29iamVjdCcgJiYgIShwYXJhbSA9PSBudWxsIHx8IHBhcmFtIGluc3RhbmNlb2YgU3RyaW5nIHx8IHBhcmFtIGluc3RhbmNlb2YgTnVtYmVyIHx8XG4gICAgICAgIHBhcmFtIGluc3RhbmNlb2YgQm9vbGVhbiB8fCBwYXJhbSBpbnN0YW5jZW9mIERhdGUpKSB7XG4gICAgICAgIHJldHVybiBKU09OLnN0cmluZ2lmeShwYXJhbSk7XG4gICAgfVxuICAgIHJldHVybiBwYXJhbTtcbn1cblxuIDsoe30pOyAvLyBALS1lbmQtb2YtZmlsZS1mb3ItbW9kdWxlPXRhb24tdHlwZS1zcWwgbGliL2NvbnZlcnRlci9wYXJhbS1jb252ZXJ0ZXIudHMiXX0=
@@ -1,17 +0,0 @@
1
- import { createQueryConverter } from "./query-converter";
2
- import { convertEscapedParam } from './param-converter';
3
- let pgParamConverter = (index) => '$' + index;
4
- let mySqlParamConverter = (index) => '?';
5
- function convertSingleParam(param, params, paramConverter) {
6
- params.push(convertEscapedParam(param));
7
- return paramConverter(params.length);
8
- }
9
- export function convertQueryToParameterizedSQL(query, options, engine) {
10
- let params = [];
11
- let paramConverter = engine === 'mysql' ? mySqlParamConverter : pgParamConverter;
12
- let sql = createQueryConverter((param) => convertSingleParam(param, params, paramConverter), options, engine)(query);
13
- return { sql, params };
14
- }
15
- ;
16
- ({}); // @--end-of-file-for-module=taon-type-sql lib/converter/parameterized-converter.ts
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyYW1ldGVyaXplZC1jb252ZXJ0ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi90bXAtbGlicy1mb3ItZGlzdC13ZWJzcWwvdGFvbi10eXBlLXNxbC9wcm9qZWN0cy90YW9uLXR5cGUtc3FsL3NyYy9saWIvY29udmVydGVyL3BhcmFtZXRlcml6ZWQtY29udmVydGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLG1CQUFtQixDQUFDO0FBQ3ZELE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLG1CQUFtQixDQUFDO0FBR3RELElBQUksZ0JBQWdCLEdBQUcsQ0FBQyxLQUFhLEVBQUUsRUFBRSxDQUFDLEdBQUcsR0FBRyxLQUFLLENBQUM7QUFDdEQsSUFBSSxtQkFBbUIsR0FBRyxDQUFDLEtBQWEsRUFBRSxFQUFFLENBQUMsR0FBRyxDQUFDO0FBRWpELFNBQVMsa0JBQWtCLENBQUMsS0FBVSxFQUFFLE1BQWEsRUFBRSxjQUFzQztJQUN6RixNQUFNLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDeEMsT0FBTyxjQUFjLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0FBQ3pDLENBQUM7QUFFRCxNQUFNLFVBQVUsOEJBQThCLENBQUMsS0FBVSxFQUFFLE9BQXlCLEVBQUUsTUFBbUI7SUFDckcsSUFBSSxNQUFNLEdBQVUsRUFBRSxDQUFDO0lBRXZCLElBQUksY0FBYyxHQUFHLE1BQU0sS0FBSyxPQUFPLENBQUMsQ0FBQyxDQUFDLG1CQUFtQixDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQztJQUNqRixJQUFJLEdBQUcsR0FBRyxvQkFBb0IsQ0FBQyxDQUFDLEtBQVUsRUFBRSxFQUFFLENBQUMsa0JBQWtCLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRSxjQUFjLENBQUMsRUFBRSxPQUFPLEVBQUUsTUFBTSxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUM7SUFFMUgsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLEVBQUUsQ0FBQztBQUMzQixDQUFDO0FBRUEsQ0FBQztBQUFBLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxtRkFBbUYiLCJzb3VyY2VzQ29udGVudCI6WyJcblxuaW1wb3J0IHtjcmVhdGVRdWVyeUNvbnZlcnRlcn0gZnJvbSBcIi4vcXVlcnktY29udmVydGVyXCI7XG5pbXBvcnQge2NvbnZlcnRFc2NhcGVkUGFyYW19IGZyb20gJy4vcGFyYW0tY29udmVydGVyJztcbmltcG9ydCB7UXVlcnlFbmdpbmUsIENvbnZlcnRlck9wdGlvbnN9IGZyb20gXCIuL3R5cGVzXCI7XG5cbmxldCBwZ1BhcmFtQ29udmVydGVyID0gKGluZGV4OiBudW1iZXIpID0+ICckJyArIGluZGV4O1xubGV0IG15U3FsUGFyYW1Db252ZXJ0ZXIgPSAoaW5kZXg6IG51bWJlcikgPT4gJz8nO1xuXG5mdW5jdGlvbiBjb252ZXJ0U2luZ2xlUGFyYW0ocGFyYW06IGFueSwgcGFyYW1zOiBhbnlbXSwgcGFyYW1Db252ZXJ0ZXI6IChwYXJhbTogYW55KSA9PiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHBhcmFtcy5wdXNoKGNvbnZlcnRFc2NhcGVkUGFyYW0ocGFyYW0pKTtcbiAgICByZXR1cm4gcGFyYW1Db252ZXJ0ZXIocGFyYW1zLmxlbmd0aCk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjb252ZXJ0UXVlcnlUb1BhcmFtZXRlcml6ZWRTUUwocXVlcnk6IGFueSwgb3B0aW9uczogQ29udmVydGVyT3B0aW9ucywgZW5naW5lOiBRdWVyeUVuZ2luZSkge1xuICAgIGxldCBwYXJhbXM6IGFueVtdID0gW107XG5cbiAgICBsZXQgcGFyYW1Db252ZXJ0ZXIgPSBlbmdpbmUgPT09ICdteXNxbCcgPyBteVNxbFBhcmFtQ29udmVydGVyIDogcGdQYXJhbUNvbnZlcnRlcjtcbiAgICBsZXQgc3FsID0gY3JlYXRlUXVlcnlDb252ZXJ0ZXIoKHBhcmFtOiBhbnkpID0+IGNvbnZlcnRTaW5nbGVQYXJhbShwYXJhbSwgcGFyYW1zLCBwYXJhbUNvbnZlcnRlciksIG9wdGlvbnMsIGVuZ2luZSkocXVlcnkpO1xuXG4gICAgcmV0dXJuIHsgc3FsLCBwYXJhbXMgfTtcbn1cblxuIDsoe30pOyAvLyBALS1lbmQtb2YtZmlsZS1mb3ItbW9kdWxlPXRhb24tdHlwZS1zcWwgbGliL2NvbnZlcnRlci9wYXJhbWV0ZXJpemVkLWNvbnZlcnRlci50cyJdfQ==
@@ -1,282 +0,0 @@
1
- import { string, number, date, boolean } from './type-converter';
2
- export function createQueryConverter(paramConverter, options, engine) {
3
- return convertQuery;
4
- function convertQuery(query) {
5
- if (query._action === 'select')
6
- return convertSelectQuery(query);
7
- if (query._action === 'delete')
8
- return convertDeleteQuery(query);
9
- if (query._action === 'update')
10
- return convertUpdateQuery(query);
11
- if (query._action === 'insert')
12
- return convertInsertQuery(query);
13
- throw new Error('Unknown query type:' + query._action);
14
- }
15
- function convertDeleteQuery(query) {
16
- let s = 'DELETE FROM ' + convertTable(query._table);
17
- s += convertConditions(query._conditions);
18
- return s;
19
- }
20
- function convertUpdateQuery(query) {
21
- let s = 'UPDATE ' + convertTable(query._table) + ' SET ';
22
- s += convertUpdateSetters(query._table, query._entity);
23
- s += convertConditions(query._conditions);
24
- return s;
25
- }
26
- function convertUpdateSetters(table, entity) {
27
- return Object.keys(entity).sort().map(key => {
28
- let value = entity[key];
29
- let column = table[key];
30
- return convertColumnName(column) + ' = ' + convertParam(column, value);
31
- }).join(', ');
32
- }
33
- function convertInsertQuery(query) {
34
- let items = Array.isArray(query._entity) ? query._entity : [query._entity];
35
- let keySet = items.reduce((set, item) => {
36
- Object.keys(item).forEach(key => set.add(key));
37
- return set;
38
- }, new Set());
39
- let keys = Array.from(keySet).sort();
40
- let s = 'INSERT INTO ' + convertTable(query._table) + ' ';
41
- s += '(' + keys.map(key => convertColumnName(query._table[key])).join(', ') + ')';
42
- s += options.lineBreak + 'VALUES ';
43
- s += items.map(item => convertInsertItem(query._table, item, keys))
44
- .map((row) => '(' + row + ')').join(', ');
45
- s += getPgInsertReturningIfNeeded(query);
46
- return s;
47
- }
48
- function getPgInsertReturningIfNeeded(query) {
49
- if (engine === 'pg' && query._action === 'insert' && !Array.isArray(query._entity) &&
50
- query._table.$id && query._table.$id._table && query._table.$id._name) {
51
- return ' RETURNING ' + convertColumnName(query._table.$id);
52
- }
53
- return '';
54
- }
55
- function convertInsertItem(table, entity, keys) {
56
- return keys.map(key => {
57
- let value = entity[key];
58
- let column = table[key];
59
- return convertParam(column, value);
60
- }).join(', ');
61
- }
62
- function convertSelectQuery(query) {
63
- let s = 'SELECT ';
64
- if (query._distinct) {
65
- s += 'DISTINCT ';
66
- }
67
- if (query._columns == null || query._columns.length === 0) {
68
- s += '*';
69
- }
70
- else {
71
- s += query._columns.map((column) => convertColumn(column)).join(', ');
72
- }
73
- s += options.lineBreak + 'FROM ';
74
- if (query._tables) {
75
- s += query._tables.map((table) => table._parent ? convertJoin(table) : convertTable(table)).join(', ');
76
- }
77
- else {
78
- s += convertTable(query._table);
79
- }
80
- s += convertConditions(query._conditions);
81
- if (query._groupBy && query._groupBy.length > 0) {
82
- s += options.lineBreak + 'GROUP BY ';
83
- s += query._groupBy.map((column) => convertColumn(column)).join(', ');
84
- }
85
- s += convertConditions(query._having, 'HAVING');
86
- if (query._orderings && query._orderings.length > 0) {
87
- s += options.lineBreak + 'ORDER BY ';
88
- s += query._orderings.map((ordering) => convertOrdering(ordering)).join(', ');
89
- }
90
- if (query._limit != null) {
91
- s += options.lineBreak + 'LIMIT ' + number(query._limit);
92
- }
93
- if (query._offset != null) {
94
- s += options.lineBreak + 'OFFSET ' + number(query._offset);
95
- }
96
- return s;
97
- }
98
- function convertConditions(conditions, keyword = 'WHERE') {
99
- let s = '';
100
- if (conditions && conditions.length > 0) {
101
- s += options.lineBreak + keyword + ' ';
102
- preprocessConditions(conditions);
103
- s += conditions.map(condition => convertCondition(condition, true)).join(' AND ');
104
- }
105
- return s;
106
- }
107
- function convertJoin(joinChain) {
108
- let items = [];
109
- while (joinChain) {
110
- items.push(joinChain);
111
- joinChain = joinChain._parent;
112
- }
113
- let root = items[items.length - 1];
114
- let s = convertTable(root);
115
- for (let i = items.length - 2; i >= 0; i -= 2) {
116
- let table = items[i]._table;
117
- let modifier = items[i]._modifier;
118
- let condition = items[i - 1]._condition;
119
- let param = convertColumn(condition._otherColumn);
120
- s += ' ' + modifier.toUpperCase() + ' JOIN ' + convertTable(table) + ' ON ' +
121
- convertColumnCondition(condition, param);
122
- }
123
- return s;
124
- }
125
- function convertOrdering(ordering) {
126
- if (ordering._column) {
127
- let s = convertColumn(ordering._column);
128
- if (ordering._nullsPosition != null) { // "NULLS FIRST" only exists in PG, this is the general solution
129
- s += ' IS NULL ' + (ordering._nullsPosition === 'FIRST' ? 'DESC' : 'ASC') + ', ' + s;
130
- }
131
- if (ordering._direction === 'ASC')
132
- s += ' ASC';
133
- if (ordering._direction === 'DESC')
134
- s += ' DESC';
135
- return s;
136
- }
137
- else {
138
- return convertColumn(ordering);
139
- }
140
- }
141
- function convertTable(table) {
142
- return options.nameEscape + table._$name + options.nameEscape;
143
- }
144
- function convertColumn(column) {
145
- let s = '';
146
- if (!(column._name === '*' && column._modifiers.length > 0 && column._modifiers[0].name === 'count')) {
147
- s += convertTable(column._table) + '.';
148
- }
149
- s += convertColumnName(column);
150
- return convertColumnModifiers(s, column);
151
- }
152
- function convertColumnModifiers(s, column) {
153
- if (column._modifiers) {
154
- column._modifiers.forEach((modifier) => {
155
- let name = modifier.name;
156
- if (name === 'lower')
157
- s = 'LOWER(' + s + ')';
158
- else if (name === 'upper')
159
- s = 'UPPER(' + s + ')';
160
- else if (name === 'count')
161
- s = 'COUNT(' + s + ')';
162
- else if (name === 'sum')
163
- s = 'SUM(' + s + ')';
164
- else if (name === 'avg')
165
- s = 'AVG(' + s + ')';
166
- else if (name === 'min')
167
- s = 'MIN(' + s + ')';
168
- else if (name === 'max')
169
- s = 'MAX(' + s + ')';
170
- else if (name === 'as')
171
- s = s + ' AS ' + options.nameEscape + modifier.params + options.nameEscape;
172
- });
173
- }
174
- return s + '';
175
- }
176
- function convertColumnName(column) {
177
- if (column._name === '*')
178
- return column._name;
179
- let name = typeof column._name === 'string' ? column._name : column._name.name;
180
- return options.nameEscape + name + options.nameEscape;
181
- }
182
- function preprocessConditions(conditions) {
183
- conditions.forEach(condition => {
184
- if (conditions.length > 1 && condition._sibling) {
185
- condition._parenthesis = true;
186
- }
187
- preprocessParams(condition);
188
- });
189
- }
190
- function preprocessParams(condition) {
191
- if (condition._sibling) {
192
- preprocessParams(condition._sibling);
193
- }
194
- if (!condition._sibling && !condition._child) {
195
- condition.__param = getConditionParam(condition);
196
- }
197
- if (condition._child) {
198
- preprocessParams(condition._child);
199
- }
200
- }
201
- function convertCondition(condition, root = false) {
202
- if (!condition._sibling && !condition._child) {
203
- return convertColumnCondition(condition, condition.__param);
204
- }
205
- let s = '';
206
- if (condition._child) {
207
- s += convertCondition(condition._child);
208
- }
209
- if (condition._sibling) {
210
- s = convertCondition(condition._sibling, root) + ' ' + condition._chainType.toUpperCase() + ' ' + s;
211
- }
212
- if (condition._parenthesis || ((!root || condition._negation) && condition._child)) {
213
- s = '( ' + s + ' )';
214
- }
215
- if (condition._negation) {
216
- s = 'NOT ' + s;
217
- }
218
- return s;
219
- }
220
- function convertColumnCondition(condition, param) {
221
- let s = convertColumn(condition._column);
222
- s += getConditionString(condition, param);
223
- return s;
224
- }
225
- function getConditionString(condition, param) {
226
- switch (condition._type) {
227
- case 'eq': return ' = ' + param;
228
- case 'ne': return ' <> ' + param;
229
- case 'lt': return ' < ' + param;
230
- case 'gt': return ' > ' + param;
231
- case 'lte': return ' <= ' + param;
232
- case 'gte': return ' >= ' + param;
233
- case 'is-null': return ' IS NULL';
234
- case 'is-not-null': return ' IS NOT NULL';
235
- case 'like': return ' LIKE ' + param;
236
- case 'not-like': return ' NOT LIKE ' + param;
237
- case 'in': return ' IN (' + param + ')';
238
- case 'not-in': return ' NOT IN (' + param + ')';
239
- case 'between': return ' BETWEEN ' + param;
240
- case 'not-between': return ' NOT BETWEEN ' + param;
241
- default: return '';
242
- }
243
- }
244
- function getConditionParam(condition) {
245
- let param = '';
246
- if (condition._otherColumn) {
247
- param = convertColumn(condition._otherColumn);
248
- }
249
- else {
250
- let _convertParam = (param) => convertParam(condition._column, param);
251
- if (condition._type === 'in' || condition._type === 'not-in') {
252
- param = condition._values.map((value) => _convertParam(value)).join(', ');
253
- }
254
- else if (condition._type === 'between' || condition._type === 'not-between') {
255
- param = _convertParam(condition._values[0]) + ' AND ' + _convertParam(condition._values[1]);
256
- }
257
- else if (condition._type !== 'is-null' && condition._type !== 'is-not-null') {
258
- param = _convertParam(condition._values[0]);
259
- }
260
- }
261
- return param;
262
- }
263
- function convertParam(column, param) {
264
- if (param == null)
265
- return 'NULL';
266
- return paramConverter(getTypedParam(column._type, param));
267
- }
268
- function getTypedParam(type, param) {
269
- if (type === 'number')
270
- return number(param);
271
- else if (type === 'boolean')
272
- return boolean(param);
273
- else if (type === 'date')
274
- return date(param);
275
- else if (type === 'string')
276
- return string(param);
277
- return param;
278
- }
279
- }
280
- ;
281
- ({}); // @--end-of-file-for-module=taon-type-sql lib/converter/query-converter.ts
282
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-converter.js","sourceRoot":"","sources":["../../../../../tmp-libs-for-dist-websql/taon-type-sql/projects/taon-type-sql/src/lib/converter/query-converter.ts"],"names":[],"mappings":"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","sourcesContent":["\n\nimport { string, number, date, boolean } from './type-converter';\nimport { QueryEngine, ConverterOptions } from \"./types\";\n\n\nexport function createQueryConverter(paramConverter: (param: any) => string, options: ConverterOptions, engine: QueryEngine) {\n\n    return convertQuery;\n\n    function convertQuery(query: any): string {\n        if (query._action === 'select') return convertSelectQuery(query);\n        if (query._action === 'delete') return convertDeleteQuery(query);\n        if (query._action === 'update') return convertUpdateQuery(query);\n        if (query._action === 'insert') return convertInsertQuery(query);\n        throw new Error('Unknown query type:' + query._action);\n    }\n\n    function convertDeleteQuery(query: any): string {\n        let s = 'DELETE FROM ' + convertTable(query._table);\n        s += convertConditions(query._conditions);\n        return s;\n    }\n\n    function convertUpdateQuery(query: any): string {\n        let s = 'UPDATE ' + convertTable(query._table) + ' SET ';\n        s += convertUpdateSetters(query._table, query._entity);\n        s += convertConditions(query._conditions);\n        return s;\n    }\n\n    function convertUpdateSetters(table: any, entity: any): string {\n        return Object.keys(entity).sort().map(key => {\n            let value = entity[key];\n            let column = table[key];\n            return convertColumnName(column) + ' = ' + convertParam(column, value);\n        }).join(', ');\n    }\n\n    function convertInsertQuery(query: any): string {\n        let items: any[] = Array.isArray(query._entity) ? query._entity : [query._entity];\n        let keySet: Set<string> = items.reduce((set: Set<string>, item) => {\n            Object.keys(item).forEach(key => set.add(key)); return set;\n        }, new Set<string>());\n        let keys = Array.from(keySet).sort();\n\n        let s = 'INSERT INTO ' + convertTable(query._table) + ' ';\n        s += '(' + keys.map(key => convertColumnName(query._table[key])).join(', ') + ')';\n        s += options.lineBreak + 'VALUES ';\n        s += items.map(item => convertInsertItem(query._table, item, keys))\n            .map((row: string) => '(' + row + ')').join(', ');\n\n        s += getPgInsertReturningIfNeeded(query);\n        return s;\n    }\n\n\n    function getPgInsertReturningIfNeeded(query: any): string {\n        if (engine === 'pg' && query._action === 'insert' && !Array.isArray(query._entity) &&\n            query._table.$id && query._table.$id._table && query._table.$id._name) {\n            return ' RETURNING ' + convertColumnName(query._table.$id);\n        }\n        return '';\n    }\n\n    function convertInsertItem(table: any, entity: any, keys: string[]): string {\n        return keys.map(key => {\n            let value = entity[key];\n            let column = table[key];\n            return convertParam(column, value);\n        }).join(', ');\n    }\n\n    function convertSelectQuery(query: any): string {\n        let s = 'SELECT ';\n        if (query._distinct) {\n            s += 'DISTINCT ';\n        }\n\n        if (query._columns == null || query._columns.length === 0) {\n            s += '*'\n        } else {\n            s += query._columns.map((column: any) => convertColumn(column)).join(', ');\n        }\n\n        s += options.lineBreak + 'FROM ';\n        if (query._tables) {\n            s+= query._tables.map((table: any) => table._parent ? convertJoin(table) : convertTable(table)).join(', ');\n        } else {\n            s+= convertTable(query._table);\n        }\n\n        s += convertConditions(query._conditions);\n\n        if (query._groupBy && query._groupBy.length > 0) {\n            s += options.lineBreak + 'GROUP BY ';\n            s += query._groupBy.map((column: any) => convertColumn(column)).join(', ');\n        }\n        s += convertConditions(query._having, 'HAVING');\n\n        if (query._orderings && query._orderings.length > 0) {\n            s += options.lineBreak + 'ORDER BY ';\n            s += query._orderings.map((ordering: any) => convertOrdering(ordering)).join(', ');\n        }\n        if (query._limit != null) {\n            s += options.lineBreak + 'LIMIT ' + number(query._limit);\n        }\n        if (query._offset != null) {\n            s += options.lineBreak + 'OFFSET ' + number(query._offset);\n        }\n        return s;\n    }\n\n    function convertConditions(conditions: any[], keyword = 'WHERE'): string {\n        let s = '';\n        if (conditions && conditions.length > 0) {\n            s += options.lineBreak + keyword + ' ';\n            preprocessConditions(conditions);\n            s += conditions.map(condition => convertCondition(condition, true)).join(' AND ');\n        }\n        return s;\n    }\n\n    function convertJoin(joinChain: any): string {\n        let items: any[] = [];\n        while (joinChain) {\n            items.push(joinChain);\n            joinChain = joinChain._parent;\n        }\n\n        let root = items[items.length - 1];\n        let s = convertTable(root);\n\n        for (let i = items.length - 2; i >= 0; i-= 2) {\n            let table = items[i]._table;\n            let modifier = items[i]._modifier;\n            let condition = items[i - 1]._condition;\n            let param = convertColumn(condition._otherColumn);\n            s += ' ' + modifier.toUpperCase() + ' JOIN ' + convertTable(table) + ' ON ' +\n                convertColumnCondition(condition, param);\n        }\n\n        return s;\n    }\n\n    function convertOrdering(ordering: any): string {\n        if (ordering._column) {\n            let s = convertColumn(ordering._column);\n\n            if (ordering._nullsPosition != null) { // \"NULLS FIRST\" only exists in PG, this is the general solution\n                s += ' IS NULL ' + (ordering._nullsPosition === 'FIRST' ? 'DESC' : 'ASC') + ', ' + s;\n            }\n\n            if (ordering._direction === 'ASC') s += ' ASC';\n            if (ordering._direction === 'DESC') s += ' DESC';\n\n            return s;\n        } else {\n            return convertColumn(ordering);\n        }\n    }\n\n    function convertTable(table: any): string {\n        return options.nameEscape + table._$name + options.nameEscape;\n    }\n\n    function convertColumn(column: any): string {\n        let s = '';\n        if (!(column._name === '*' && column._modifiers.length > 0 && column._modifiers[0].name === 'count')) {\n            s += convertTable(column._table) + '.';\n        }\n        s += convertColumnName(column);\n        return convertColumnModifiers(s, column);\n    }\n\n    function convertColumnModifiers(s: string, column: any): string {\n        if (column._modifiers) {\n            column._modifiers.forEach((modifier: any) => {\n                let name = modifier.name;\n                if (name === 'lower') s = 'LOWER(' + s + ')';\n                else if (name === 'upper') s = 'UPPER(' + s + ')';\n                else if (name === 'count') s = 'COUNT(' + s + ')';\n                else if (name === 'sum') s = 'SUM(' + s + ')';\n                else if (name === 'avg') s = 'AVG(' + s + ')';\n                else if (name === 'min') s = 'MIN(' + s + ')';\n                else if (name === 'max') s = 'MAX(' + s + ')';\n                else if (name === 'as') s = s + ' AS ' + options.nameEscape + modifier.params + options.nameEscape;\n            });\n        }\n        return s + '';\n    }\n\n    function convertColumnName(column: any): string {\n        if (column._name === '*') return column._name;\n        let name = typeof column._name === 'string' ? column._name : column._name.name;\n        return options.nameEscape + name + options.nameEscape;\n    }\n\n    function preprocessConditions(conditions: any[]): void {\n        conditions.forEach(condition => {\n            if (conditions.length > 1 && condition._sibling) {\n                condition._parenthesis = true;\n            }\n            preprocessParams(condition);\n        });\n    }\n\n\n    function preprocessParams(condition: any): void {\n        if (condition._sibling) {\n            preprocessParams(condition._sibling);\n        }\n        if (!condition._sibling && !condition._child) {\n            condition.__param = getConditionParam(condition);\n        }\n        if (condition._child) {\n            preprocessParams(condition._child);\n        }\n    }\n\n    function convertCondition(condition: any, root = false): string {\n        if (!condition._sibling && !condition._child) {\n            return convertColumnCondition(condition, condition.__param);\n        }\n\n        let s = '';\n        if (condition._child) {\n            s += convertCondition(condition._child);\n        }\n        if (condition._sibling) {\n            s = convertCondition(condition._sibling, root) + ' ' + condition._chainType.toUpperCase() + ' ' + s;\n        }\n        if (condition._parenthesis || ((!root || condition._negation) && condition._child)) {\n            s = '( ' + s + ' )';\n        }\n        if (condition._negation) {\n            s = 'NOT ' + s;\n        }\n        return s;\n    }\n\n    function convertColumnCondition(condition: any, param: string): string {\n        let s = convertColumn(condition._column);\n        s += getConditionString(condition, param);\n        return s;\n    }\n\n    function getConditionString(condition: any, param: string): string {\n        switch (condition._type) {\n            case 'eq': return ' = ' + param;\n            case 'ne': return ' <> ' + param;\n            case 'lt': return ' < ' + param;\n            case 'gt': return ' > ' + param;\n            case 'lte': return ' <= ' + param;\n            case 'gte': return ' >= ' + param;\n            case 'is-null': return ' IS NULL';\n            case 'is-not-null': return ' IS NOT NULL';\n            case 'like': return ' LIKE ' + param;\n            case 'not-like': return ' NOT LIKE ' + param;\n            case 'in': return ' IN (' + param + ')';\n            case 'not-in': return ' NOT IN (' + param + ')';\n            case 'between': return ' BETWEEN ' + param;\n            case 'not-between': return ' NOT BETWEEN ' + param;\n            default: return '';\n        }\n    }\n\n    function getConditionParam(condition: any): string {\n        let param = '';\n        if (condition._otherColumn) {\n            param = convertColumn(condition._otherColumn);\n        } else {\n            let _convertParam = (param: any) => convertParam(condition._column, param);\n\n            if (condition._type === 'in' || condition._type === 'not-in') {\n                param = condition._values.map((value: any) => _convertParam(value)).join(', ');\n            } else if (condition._type === 'between' || condition._type === 'not-between') {\n                param = _convertParam(condition._values[0]) + ' AND ' + _convertParam(condition._values[1]);\n            } else if (condition._type !== 'is-null' && condition._type !== 'is-not-null') {\n                param = _convertParam(condition._values[0]);\n            }\n        }\n        return param;\n    }\n\n    function convertParam(column: any, param: any): string {\n        if (param == null) return 'NULL';\n        return paramConverter(getTypedParam(column._type, param));\n    }\n\n    function getTypedParam(type: string, param: any): any {\n        if (type === 'number') return number(param);\n        else if (type === 'boolean') return boolean(param);\n        else if (type === 'date') return date(param);\n        else if (type === 'string') return string(param);\n        return param;\n    }\n}\n\n ;({}); // @--end-of-file-for-module=taon-type-sql lib/converter/query-converter.ts"]}
@@ -1,88 +0,0 @@
1
- export function convertResult(query, result, engine) {
2
- let rows = engine === 'pg' ? result.rows : result;
3
- let rowCount = engine === 'pg' ? result.rowCount : result.affectedRows || result.changedRows;
4
- if (query._action === 'select')
5
- return convertSelectResult(query, rows);
6
- if (query._action === 'delete')
7
- return rowCount;
8
- if (query._action === 'update')
9
- return rowCount;
10
- if (query._action === 'insert')
11
- return convertInsertResult(result, engine);
12
- throw new Error('Unknown query type:' + query._action);
13
- }
14
- function convertInsertResult(result, engine) {
15
- if (engine === 'mysql')
16
- return result.insertId > 0 ? result.insertId : undefined; // mysql returns 0 for tables that have a non-autoincrement ID
17
- if (engine === 'pg' && result.rows && result.rows.length === 1) {
18
- let columnName = Object.keys(result.rows[0])[0];
19
- return result.rows[0][columnName];
20
- }
21
- }
22
- function convertSelectResult(query, rows) {
23
- if (query._columns && query._columns.length === 1 &&
24
- !(query._columns[0]._name === '*' && query._columns[0]._modifiers.length === 0)) {
25
- if (rows.length == 0)
26
- return [];
27
- let columnName = Object.keys(rows[0])[0]; // easier than reverse engineering from the column modifiers
28
- let values = rows.map((row) => row[columnName]);
29
- if (query._columns[0]._name === '*' && query._columns[0]._modifiers.some((m) => m.name === 'count')) {
30
- return values.map((value) => Number(value)); // string to number conversion for PG count values
31
- }
32
- return values;
33
- }
34
- else {
35
- convertAliasFields(query, rows);
36
- return rows;
37
- }
38
- }
39
- function convertAliasFields(query, rows) {
40
- let aliasByName = getColumnAliasesByName(query);
41
- if (Object.keys(aliasByName).length === 0)
42
- return;
43
- rows.forEach((row) => {
44
- Object.keys(row).forEach((name) => {
45
- if (aliasByName[name]) {
46
- row[aliasByName[name]] = row[name];
47
- delete row[name];
48
- }
49
- });
50
- });
51
- }
52
- function getColumnAliasesByName(query) {
53
- let aliasByName = {};
54
- if (query._columns && query._columns.length > 0) {
55
- query._columns.forEach((column) => {
56
- if (column._name && column._name.alias && column._modifiers.length === 0) {
57
- aliasByName[column._name.name] = column._name.alias;
58
- }
59
- else if (column._name === '*' && column._modifiers.length === 0) {
60
- getAliasColumnsOfTable(column._table).forEach((column) => {
61
- aliasByName[column._name.name] = column._name.alias;
62
- });
63
- }
64
- });
65
- }
66
- else {
67
- let tables = query._table ? [query._table] : query._tables;
68
- tables.forEach((table) => {
69
- getAliasColumnsOfTable(table).forEach((column) => {
70
- aliasByName[column._name.name] = column._name.alias;
71
- });
72
- let joinTable = table._parent;
73
- while (joinTable) {
74
- getAliasColumnsOfTable(joinTable).forEach((column) => {
75
- aliasByName[column._name.name] = column._name.alias;
76
- });
77
- joinTable = joinTable._parent;
78
- }
79
- });
80
- }
81
- return aliasByName;
82
- }
83
- function getAliasColumnsOfTable(table) {
84
- return Object.keys(table).map(key => table[key]).filter((column) => column && column._name && column._name.alias);
85
- }
86
- ;
87
- ({}); // @--end-of-file-for-module=taon-type-sql lib/converter/result-converter.ts
88
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"result-converter.js","sourceRoot":"","sources":["../../../../../tmp-libs-for-dist-websql/taon-type-sql/projects/taon-type-sql/src/lib/converter/result-converter.ts"],"names":[],"mappings":"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","sourcesContent":["\n\nimport { QueryEngine } from \"./types\";\n\nexport function convertResult(query: any, result: any, engine: QueryEngine): any {\n  let rows = engine === 'pg' ? result.rows : result;\n  let rowCount = engine === 'pg' ? result.rowCount : result.affectedRows || result.changedRows;\n\n  if (query._action === 'select') return convertSelectResult(query, rows);\n  if (query._action === 'delete') return rowCount;\n  if (query._action === 'update') return rowCount;\n  if (query._action === 'insert') return convertInsertResult(result, engine);\n  throw new Error('Unknown query type:' + query._action);\n}\n\nfunction convertInsertResult(result: any, engine: QueryEngine): any {\n  if (engine === 'mysql') return result.insertId > 0 ? result.insertId : undefined; // mysql returns 0 for tables that have a non-autoincrement ID\n  if (engine === 'pg' && result.rows && result.rows.length === 1) {\n    let columnName = Object.keys(result.rows[0])[0];\n    return result.rows[0][columnName];\n  }\n}\n\nfunction convertSelectResult(query: any, rows: any[]): any {\n  if (query._columns && query._columns.length === 1 &&\n    !(query._columns[0]._name === '*' && query._columns[0]._modifiers.length === 0)) {\n    if (rows.length == 0) return [];\n    let columnName = Object.keys(rows[0])[0]; // easier than reverse engineering from the column modifiers\n    let values = rows.map((row: any) => row[columnName]);\n\n    if (query._columns[0]._name === '*' && query._columns[0]._modifiers.some((m: any) => m.name === 'count')) {\n      return values.map((value: any) => Number(value)); // string to number conversion for PG count values\n    }\n    return values;\n  } else {\n    convertAliasFields(query, rows);\n    return rows;\n  }\n}\n\nfunction convertAliasFields(query: any, rows: any[]): void {\n  let aliasByName = getColumnAliasesByName(query);\n  if (Object.keys(aliasByName).length === 0) return;\n\n  rows.forEach((row: any) => {\n    Object.keys(row).forEach((name: string) => {\n      if (aliasByName[name]) {\n        row[aliasByName[name]] = row[name];\n        delete row[name];\n      }\n    });\n  });\n}\n\nfunction getColumnAliasesByName(query: any): any {\n  let aliasByName = {} as any;\n\n  if (query._columns && query._columns.length > 0) {\n    query._columns.forEach((column: any) => {\n      if (column._name && column._name.alias && column._modifiers.length === 0) {\n        aliasByName[column._name.name] = column._name.alias;\n      } else if (column._name === '*' && column._modifiers.length === 0) {\n        getAliasColumnsOfTable(column._table).forEach((column: any) => {\n          aliasByName[column._name.name] = column._name.alias;\n        });\n      }\n    });\n  } else {\n    let tables = query._table ? [query._table] : query._tables;\n    tables.forEach((table: any) => {\n      getAliasColumnsOfTable(table).forEach((column: any) => {\n        aliasByName[column._name.name] = column._name.alias;\n      });\n\n      let joinTable = table._parent;\n      while (joinTable) {\n        getAliasColumnsOfTable(joinTable).forEach((column: any) => {\n          aliasByName[column._name.name] = column._name.alias;\n        });\n        joinTable = joinTable._parent;\n      }\n    });\n  }\n\n  return aliasByName;\n}\n\nfunction getAliasColumnsOfTable(table: any): any[] {\n  return Object.keys(table).map(key => table[key]).filter((column: any) => column && column._name && column._name.alias);\n}\n\n ;({}); // @--end-of-file-for-module=taon-type-sql lib/converter/result-converter.ts"]}
@@ -1,8 +0,0 @@
1
- import { createQueryConverter } from "./query-converter";
2
- import { convertSubstitutionParam } from './param-converter';
3
- export function convertQueryToSQL(query, options, engine) {
4
- return createQueryConverter((param) => convertSubstitutionParam(param), options, engine)(query);
5
- }
6
- ;
7
- ({}); // @--end-of-file-for-module=taon-type-sql lib/converter/sql-converter.ts
8
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3FsLWNvbnZlcnRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3RtcC1saWJzLWZvci1kaXN0LXdlYnNxbC90YW9uLXR5cGUtc3FsL3Byb2plY3RzL3Rhb24tdHlwZS1zcWwvc3JjL2xpYi9jb252ZXJ0ZXIvc3FsLWNvbnZlcnRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSxtQkFBbUIsQ0FBQztBQUN2RCxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSxtQkFBbUIsQ0FBQztBQUczRCxNQUFNLFVBQVUsaUJBQWlCLENBQUMsS0FBVSxFQUFFLE9BQXlCLEVBQUUsTUFBbUI7SUFDeEYsT0FBTyxvQkFBb0IsQ0FBQyxDQUFDLEtBQVUsRUFBRSxFQUFFLENBQUMsd0JBQXdCLENBQUMsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLE1BQU0sQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO0FBQ3pHLENBQUM7QUFFQSxDQUFDO0FBQUEsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLHlFQUF5RSIsInNvdXJjZXNDb250ZW50IjpbIlxuXG5pbXBvcnQge2NyZWF0ZVF1ZXJ5Q29udmVydGVyfSBmcm9tIFwiLi9xdWVyeS1jb252ZXJ0ZXJcIjtcbmltcG9ydCB7Y29udmVydFN1YnN0aXR1dGlvblBhcmFtfSBmcm9tICcuL3BhcmFtLWNvbnZlcnRlcic7XG5pbXBvcnQge1F1ZXJ5RW5naW5lLCBDb252ZXJ0ZXJPcHRpb25zfSBmcm9tIFwiLi90eXBlc1wiO1xuXG5leHBvcnQgZnVuY3Rpb24gY29udmVydFF1ZXJ5VG9TUUwocXVlcnk6IGFueSwgb3B0aW9uczogQ29udmVydGVyT3B0aW9ucywgZW5naW5lOiBRdWVyeUVuZ2luZSk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGNyZWF0ZVF1ZXJ5Q29udmVydGVyKChwYXJhbTogYW55KSA9PiBjb252ZXJ0U3Vic3RpdHV0aW9uUGFyYW0ocGFyYW0pLCBvcHRpb25zLCBlbmdpbmUpKHF1ZXJ5KTtcbn1cblxuIDsoe30pOyAvLyBALS1lbmQtb2YtZmlsZS1mb3ItbW9kdWxlPXRhb24tdHlwZS1zcWwgbGliL2NvbnZlcnRlci9zcWwtY29udmVydGVyLnRzIl19
@@ -1,39 +0,0 @@
1
- export function number(param) {
2
- let result = Number(param);
3
- if (Number.isNaN(result))
4
- throw new Error('Invalid number parameter in SQL query: ' + param);
5
- return result;
6
- }
7
- export function boolean(param) {
8
- if (typeof param === 'boolean')
9
- return param;
10
- if (param instanceof Boolean)
11
- return param.valueOf();
12
- if (param === 'true')
13
- return true;
14
- if (param === 'false')
15
- return false;
16
- throw new Error('Invalid boolean parameter in SQL query: ' + param);
17
- }
18
- export function date(param) {
19
- if (param instanceof Date)
20
- return param; // @ts-ignore
21
- if (typeof param === 'number' || param instanceof Number)
22
- return new Date(param);
23
- if (typeof param === 'string' || param instanceof String) {
24
- if (Number.isNaN(Date.parse(String(param))))
25
- throw new Error('Invalid date parameter in SQL query: ' + param); // @ts-ignore
26
- return new Date(param);
27
- }
28
- throw new Error('Invalid date parameter in SQL query: ' + param);
29
- }
30
- export function string(param) {
31
- if (typeof param === 'string')
32
- return param;
33
- if (param instanceof String)
34
- return param.valueOf();
35
- throw new Error('Invalid string parameter in SQL query: ' + param);
36
- }
37
- ;
38
- ({}); // @--end-of-file-for-module=taon-type-sql lib/converter/type-converter.ts
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZS1jb252ZXJ0ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi90bXAtbGlicy1mb3ItZGlzdC13ZWJzcWwvdGFvbi10eXBlLXNxbC9wcm9qZWN0cy90YW9uLXR5cGUtc3FsL3NyYy9saWIvY29udmVydGVyL3R5cGUtY29udmVydGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE1BQU0sVUFBVSxNQUFNLENBQUMsS0FBVTtJQUMvQixJQUFJLE1BQU0sR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDM0IsSUFBSSxNQUFNLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQztRQUFFLE1BQU0sSUFBSSxLQUFLLENBQUMseUNBQXlDLEdBQUcsS0FBSyxDQUFDLENBQUM7SUFDN0YsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQUVELE1BQU0sVUFBVSxPQUFPLENBQUMsS0FBVTtJQUNoQyxJQUFJLE9BQU8sS0FBSyxLQUFLLFNBQVM7UUFBRSxPQUFPLEtBQUssQ0FBQztJQUM3QyxJQUFJLEtBQUssWUFBWSxPQUFPO1FBQUUsT0FBTyxLQUFLLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDckQsSUFBSSxLQUFLLEtBQUssTUFBTTtRQUFFLE9BQU8sSUFBSSxDQUFDO0lBQ2xDLElBQUksS0FBSyxLQUFLLE9BQU87UUFBRSxPQUFPLEtBQUssQ0FBQztJQUNwQyxNQUFNLElBQUksS0FBSyxDQUFDLDBDQUEwQyxHQUFHLEtBQUssQ0FBQyxDQUFDO0FBQ3RFLENBQUM7QUFFRCxNQUFNLFVBQVUsSUFBSSxDQUFDLEtBQVU7SUFDN0IsSUFBSSxLQUFLLFlBQVksSUFBSTtRQUFFLE9BQU8sS0FBSyxDQUFDLENBQUMsYUFBYTtJQUN0RCxJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsSUFBSSxLQUFLLFlBQVksTUFBTTtRQUFFLE9BQU8sSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakYsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLElBQUksS0FBSyxZQUFZLE1BQU0sRUFBRSxDQUFDO1FBQ3pELElBQUksTUFBTSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1lBQUUsTUFBTSxJQUFJLEtBQUssQ0FBQyx1Q0FBdUMsR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLGFBQWE7UUFDNUgsT0FBTyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN6QixDQUFDO0lBQ0QsTUFBTSxJQUFJLEtBQUssQ0FBQyx1Q0FBdUMsR0FBRyxLQUFLLENBQUMsQ0FBQztBQUNuRSxDQUFDO0FBRUQsTUFBTSxVQUFVLE1BQU0sQ0FBQyxLQUFVO0lBQy9CLElBQUksT0FBTyxLQUFLLEtBQUssUUFBUTtRQUFFLE9BQU8sS0FBSyxDQUFDO0lBQzVDLElBQUksS0FBSyxZQUFZLE1BQU07UUFBRSxPQUFPLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUNwRCxNQUFNLElBQUksS0FBSyxDQUFDLHlDQUF5QyxHQUFHLEtBQUssQ0FBQyxDQUFDO0FBQ3JFLENBQUM7QUFFQSxDQUFDO0FBQUEsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLDBFQUEwRSIsInNvdXJjZXNDb250ZW50IjpbIlxuXG5cbmV4cG9ydCBmdW5jdGlvbiBudW1iZXIocGFyYW06IGFueSk6IG51bWJlciB7XG4gIGxldCByZXN1bHQgPSBOdW1iZXIocGFyYW0pO1xuICBpZiAoTnVtYmVyLmlzTmFOKHJlc3VsdCkpIHRocm93IG5ldyBFcnJvcignSW52YWxpZCBudW1iZXIgcGFyYW1ldGVyIGluIFNRTCBxdWVyeTogJyArIHBhcmFtKTtcbiAgcmV0dXJuIHJlc3VsdDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGJvb2xlYW4ocGFyYW06IGFueSk6IGJvb2xlYW4ge1xuICBpZiAodHlwZW9mIHBhcmFtID09PSAnYm9vbGVhbicpIHJldHVybiBwYXJhbTtcbiAgaWYgKHBhcmFtIGluc3RhbmNlb2YgQm9vbGVhbikgcmV0dXJuIHBhcmFtLnZhbHVlT2YoKTtcbiAgaWYgKHBhcmFtID09PSAndHJ1ZScpIHJldHVybiB0cnVlO1xuICBpZiAocGFyYW0gPT09ICdmYWxzZScpIHJldHVybiBmYWxzZTtcbiAgdGhyb3cgbmV3IEVycm9yKCdJbnZhbGlkIGJvb2xlYW4gcGFyYW1ldGVyIGluIFNRTCBxdWVyeTogJyArIHBhcmFtKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGRhdGUocGFyYW06IGFueSk6IERhdGUge1xuICBpZiAocGFyYW0gaW5zdGFuY2VvZiBEYXRlKSByZXR1cm4gcGFyYW07IC8vIEB0cy1pZ25vcmVcbiAgaWYgKHR5cGVvZiBwYXJhbSA9PT0gJ251bWJlcicgfHwgcGFyYW0gaW5zdGFuY2VvZiBOdW1iZXIpIHJldHVybiBuZXcgRGF0ZShwYXJhbSk7XG4gIGlmICh0eXBlb2YgcGFyYW0gPT09ICdzdHJpbmcnIHx8IHBhcmFtIGluc3RhbmNlb2YgU3RyaW5nKSB7XG4gICAgaWYgKE51bWJlci5pc05hTihEYXRlLnBhcnNlKFN0cmluZyhwYXJhbSkpKSkgdGhyb3cgbmV3IEVycm9yKCdJbnZhbGlkIGRhdGUgcGFyYW1ldGVyIGluIFNRTCBxdWVyeTogJyArIHBhcmFtKTsgLy8gQHRzLWlnbm9yZVxuICAgIHJldHVybiBuZXcgRGF0ZShwYXJhbSk7XG4gIH1cbiAgdGhyb3cgbmV3IEVycm9yKCdJbnZhbGlkIGRhdGUgcGFyYW1ldGVyIGluIFNRTCBxdWVyeTogJyArIHBhcmFtKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHN0cmluZyhwYXJhbTogYW55KTogc3RyaW5nIHtcbiAgaWYgKHR5cGVvZiBwYXJhbSA9PT0gJ3N0cmluZycpIHJldHVybiBwYXJhbTtcbiAgaWYgKHBhcmFtIGluc3RhbmNlb2YgU3RyaW5nKSByZXR1cm4gcGFyYW0udmFsdWVPZigpO1xuICB0aHJvdyBuZXcgRXJyb3IoJ0ludmFsaWQgc3RyaW5nIHBhcmFtZXRlciBpbiBTUUwgcXVlcnk6ICcgKyBwYXJhbSk7XG59XG5cbiA7KHt9KTsgLy8gQC0tZW5kLW9mLWZpbGUtZm9yLW1vZHVsZT10YW9uLXR5cGUtc3FsIGxpYi9jb252ZXJ0ZXIvdHlwZS1jb252ZXJ0ZXIudHMiXX0=
@@ -1,4 +0,0 @@
1
- ;
2
- ({}); // @--end-of-file-for-module=taon-type-sql lib/converter/types.ts
3
- export {};
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi90bXAtbGlicy1mb3ItZGlzdC13ZWJzcWwvdGFvbi10eXBlLXNxbC9wcm9qZWN0cy90YW9uLXR5cGUtc3FsL3NyYy9saWIvY29udmVydGVyL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVVDLENBQUM7QUFBQSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsaUVBQWlFIiwic291cmNlc0NvbnRlbnQiOlsiXG5cblxuZXhwb3J0IHR5cGUgUXVlcnlFbmdpbmUgPSAncGcnIHwgJ215c3FsJztcblxuZXhwb3J0IGludGVyZmFjZSBDb252ZXJ0ZXJPcHRpb25zIHtcbiAgICBsaW5lQnJlYWs6IHN0cmluZyxcbiAgICBuYW1lRXNjYXBlOiBzdHJpbmdcbn1cblxuIDsoe30pOyAvLyBALS1lbmQtb2YtZmlsZS1mb3ItbW9kdWxlPXRhb24tdHlwZS1zcWwgbGliL2NvbnZlcnRlci90eXBlcy50cyJdfQ==