@revisium/core 2.1.1 → 2.2.0

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 (185) hide show
  1. package/dist/package.json +3 -1
  2. package/dist/src/__tests__/utils/queryTest.d.ts +1 -1
  3. package/dist/src/__tests__/utils/queryTest.js +1 -1
  4. package/dist/src/__tests__/utils/queryTest.js.map +1 -1
  5. package/dist/src/api/graphql-api/graphql-api.module.js +2 -0
  6. package/dist/src/api/graphql-api/graphql-api.module.js.map +1 -1
  7. package/dist/src/api/graphql-api/registerGraphqlEnums.js +2 -0
  8. package/dist/src/api/graphql-api/registerGraphqlEnums.js.map +1 -1
  9. package/dist/src/api/graphql-api/row/inputs/get-rows.input.d.ts +19 -1
  10. package/dist/src/api/graphql-api/row/inputs/get-rows.input.js +30 -1
  11. package/dist/src/api/graphql-api/row/inputs/get-rows.input.js.map +1 -1
  12. package/dist/src/api/graphql-api/row/row.resolver.d.ts +9 -11
  13. package/dist/src/api/graphql-api/row/row.resolver.js +15 -17
  14. package/dist/src/api/graphql-api/row/row.resolver.js.map +1 -1
  15. package/dist/src/api/graphql-api/table/table.resolver.d.ts +5 -3
  16. package/dist/src/api/graphql-api/table/table.resolver.js +7 -6
  17. package/dist/src/api/graphql-api/table/table.resolver.js.map +1 -1
  18. package/dist/src/api/rest-api/rest-api.module.js +2 -0
  19. package/dist/src/api/rest-api/rest-api.module.js.map +1 -1
  20. package/dist/src/api/rest-api/row/row-by-id.controller.d.ts +5 -3
  21. package/dist/src/api/rest-api/row/row-by-id.controller.js +20 -10
  22. package/dist/src/api/rest-api/row/row-by-id.controller.js.map +1 -1
  23. package/dist/src/api/rest-api/share/model/order-by.model.d.ts +21 -1
  24. package/dist/src/api/rest-api/share/model/order-by.model.js +38 -1
  25. package/dist/src/api/rest-api/share/model/order-by.model.js.map +1 -1
  26. package/dist/src/api/rest-api/share/validators/is-unique-order-by-fields.validator.js +6 -2
  27. package/dist/src/api/rest-api/share/validators/is-unique-order-by-fields.validator.js.map +1 -1
  28. package/dist/src/api/rest-api/share/validators/is-valid-data-field-order.validator.d.ts +2 -0
  29. package/dist/src/api/rest-api/share/validators/is-valid-data-field-order.validator.js +30 -0
  30. package/dist/src/api/rest-api/share/validators/is-valid-data-field-order.validator.js.map +1 -0
  31. package/dist/src/api/rest-api/table/dto/get-table-rows.dto.js +4 -0
  32. package/dist/src/api/rest-api/table/dto/get-table-rows.dto.js.map +1 -1
  33. package/dist/src/api/rest-api/table/table-by-id.controller.d.ts +3 -1
  34. package/dist/src/api/rest-api/table/table-by-id.controller.js +8 -8
  35. package/dist/src/api/rest-api/table/table-by-id.controller.js.map +1 -1
  36. package/dist/src/api/utils/mapToPrismaOrderBy.d.ts +10 -0
  37. package/dist/src/api/utils/mapToPrismaOrderBy.js +27 -0
  38. package/dist/src/api/utils/mapToPrismaOrderBy.js.map +1 -0
  39. package/dist/src/features/draft/commands/handlers/__tests__/utils.js +6 -4
  40. package/dist/src/features/draft/commands/handlers/__tests__/utils.js.map +1 -1
  41. package/dist/src/features/draft/commands/handlers/api-base-row.handler.d.ts +4 -3
  42. package/dist/src/features/draft/commands/handlers/api-base-row.handler.js +4 -4
  43. package/dist/src/features/draft/commands/handlers/api-base-row.handler.js.map +1 -1
  44. package/dist/src/features/draft/commands/handlers/api-create-revision.handler.js +1 -1
  45. package/dist/src/features/draft/commands/handlers/api-create-revision.handler.js.map +1 -1
  46. package/dist/src/features/draft/commands/handlers/api-create-row.handler.d.ts +3 -1
  47. package/dist/src/features/draft/commands/handlers/api-create-row.handler.js +6 -3
  48. package/dist/src/features/draft/commands/handlers/api-create-row.handler.js.map +1 -1
  49. package/dist/src/features/draft/commands/handlers/api-patch-row.handler.d.ts +3 -1
  50. package/dist/src/features/draft/commands/handlers/api-patch-row.handler.js +6 -3
  51. package/dist/src/features/draft/commands/handlers/api-patch-row.handler.js.map +1 -1
  52. package/dist/src/features/draft/commands/handlers/api-rename-row.handler.d.ts +3 -1
  53. package/dist/src/features/draft/commands/handlers/api-rename-row.handler.js +6 -3
  54. package/dist/src/features/draft/commands/handlers/api-rename-row.handler.js.map +1 -1
  55. package/dist/src/features/draft/commands/handlers/api-update-row.handler.d.ts +3 -1
  56. package/dist/src/features/draft/commands/handlers/api-update-row.handler.js +6 -3
  57. package/dist/src/features/draft/commands/handlers/api-update-row.handler.js.map +1 -1
  58. package/dist/src/features/draft/commands/handlers/api-upload-file.handler.d.ts +3 -1
  59. package/dist/src/features/draft/commands/handlers/api-upload-file.handler.js +6 -3
  60. package/dist/src/features/draft/commands/handlers/api-upload-file.handler.js.map +1 -1
  61. package/dist/src/features/draft/commands/impl/api-patch-row.command.d.ts +2 -2
  62. package/dist/src/features/draft/commands/impl/api-rename-row.command.d.ts +2 -2
  63. package/dist/src/features/draft/commands/impl/api-upload-file.command.d.ts +2 -2
  64. package/dist/src/features/draft/commands/types/api-create-row.handler.types.d.ts +2 -2
  65. package/dist/src/features/draft/commands/types/api-update-row.handler.types.d.ts +2 -2
  66. package/dist/src/features/draft/draft.module.js +2 -0
  67. package/dist/src/features/draft/draft.module.js.map +1 -1
  68. package/dist/src/features/endpoint/commands/handlers/create-endpoint.handler.d.ts +2 -2
  69. package/dist/src/features/endpoint/commands/handlers/create-endpoint.handler.js +2 -2
  70. package/dist/src/features/endpoint/commands/handlers/create-endpoint.handler.js.map +1 -1
  71. package/dist/src/features/endpoint/commands/handlers/delete-endpoint.handler.js +1 -1
  72. package/dist/src/features/endpoint/commands/handlers/delete-endpoint.handler.js.map +1 -1
  73. package/dist/src/features/endpoint/commands/impl/create-endpoint.command.d.ts +2 -0
  74. package/dist/src/features/project/commands/handlers/delete-project.handler.js +3 -3
  75. package/dist/src/features/project/commands/handlers/delete-project.handler.js.map +1 -1
  76. package/dist/src/features/row/queries/handlers/get-row-by-id.handler.d.ts +2 -3
  77. package/dist/src/features/row/queries/handlers/get-row-by-id.handler.js.map +1 -1
  78. package/dist/src/features/row/queries/handlers/get-row.handler.d.ts +3 -4
  79. package/dist/src/features/row/queries/handlers/get-row.handler.js.map +1 -1
  80. package/dist/src/features/row/queries/handlers/get-rows.handler.d.ts +21 -5
  81. package/dist/src/features/row/queries/handlers/get-rows.handler.js +23 -20
  82. package/dist/src/features/row/queries/handlers/get-rows.handler.js.map +1 -1
  83. package/dist/src/features/row/queries/handlers/resolve-row-count-foreign-keys-by.handler.d.ts +3 -4
  84. package/dist/src/features/row/queries/handlers/resolve-row-count-foreign-keys-by.handler.js +2 -2
  85. package/dist/src/features/row/queries/handlers/resolve-row-count-foreign-keys-by.handler.js.map +1 -1
  86. package/dist/src/features/row/queries/handlers/resolve-row-count-foreign-keys-to.handler.d.ts +2 -2
  87. package/dist/src/features/row/queries/handlers/resolve-row-count-foreign-keys-to.handler.js.map +1 -1
  88. package/dist/src/features/row/queries/handlers/resolve-row-foreign-keys-by.handler.d.ts +1 -2
  89. package/dist/src/features/row/queries/handlers/resolve-row-foreign-keys-by.handler.js.map +1 -1
  90. package/dist/src/features/row/queries/handlers/resolve-row-foreign-keys-to.handler.d.ts +1 -2
  91. package/dist/src/features/row/queries/handlers/resolve-row-foreign-keys-to.handler.js.map +1 -1
  92. package/dist/src/features/row/queries/impl/get-row-by-id.query.d.ts +3 -0
  93. package/dist/src/features/row/queries/impl/get-row-by-id.query.js.map +1 -1
  94. package/dist/src/features/row/queries/impl/get-row.query.d.ts +3 -0
  95. package/dist/src/features/row/queries/impl/get-row.query.js.map +1 -1
  96. package/dist/src/features/row/queries/impl/get-rows.query.d.ts +15 -2
  97. package/dist/src/features/row/queries/impl/get-rows.query.js.map +1 -1
  98. package/dist/src/features/row/queries/impl/resolve-row-count-foreign-keys-by.query.d.ts +2 -0
  99. package/dist/src/features/row/queries/impl/resolve-row-count-foreign-keys-to.query.d.ts +2 -0
  100. package/dist/src/features/row/queries/impl/resolve-row-foreign-keys-by.query.d.ts +4 -0
  101. package/dist/src/features/row/queries/impl/resolve-row-foreign-keys-by.query.js.map +1 -1
  102. package/dist/src/features/row/queries/impl/resolve-row-foreign-keys-to.query.d.ts +4 -0
  103. package/dist/src/features/row/queries/impl/resolve-row-foreign-keys-to.query.js.map +1 -1
  104. package/dist/src/features/row/row-api.service.d.ts +13 -0
  105. package/dist/src/features/row/row-api.service.js +47 -0
  106. package/dist/src/features/row/row-api.service.js.map +1 -0
  107. package/dist/src/features/row/row.module.js +3 -1
  108. package/dist/src/features/row/row.module.js.map +1 -1
  109. package/dist/src/features/share/commands/handlers/notify-endpoints.handler.js +1 -1
  110. package/dist/src/features/share/commands/handlers/notify-endpoints.handler.js.map +1 -1
  111. package/dist/src/features/share/commands/handlers/transactional/move-endpoints.handler.js +1 -0
  112. package/dist/src/features/share/commands/handlers/transactional/move-endpoints.handler.js.map +1 -1
  113. package/dist/src/features/share/foreign-keys.service.d.ts +7 -4
  114. package/dist/src/features/share/foreign-keys.service.js +77 -38
  115. package/dist/src/features/share/foreign-keys.service.js.map +1 -1
  116. package/dist/src/features/share/queries/handlers/transactional/find-table-in-revision-or-throw.handler.d.ts +1 -1
  117. package/dist/src/features/share/queries/handlers/transactional/find-table-in-revision-or-throw.handler.js +3 -3
  118. package/dist/src/features/share/queries/handlers/transactional/find-table-in-revision-or-throw.handler.js.map +1 -1
  119. package/dist/src/features/table/queries/handlers/index.d.ts +1 -2
  120. package/dist/src/features/table/queries/handlers/index.js +0 -2
  121. package/dist/src/features/table/queries/handlers/index.js.map +1 -1
  122. package/dist/src/infrastructure/database/database.module.js +3 -0
  123. package/dist/src/infrastructure/database/database.module.js.map +1 -1
  124. package/dist/src/infrastructure/database/postgresql-notification.service.d.ts +7 -0
  125. package/dist/src/infrastructure/database/postgresql-notification.service.js +33 -0
  126. package/dist/src/infrastructure/database/postgresql-notification.service.js.map +1 -0
  127. package/dist/src/infrastructure/database/transaction-prisma.service.d.ts +1 -0
  128. package/dist/src/infrastructure/database/transaction-prisma.service.js +3 -0
  129. package/dist/src/infrastructure/database/transaction-prisma.service.js.map +1 -1
  130. package/dist/src/infrastructure/notification/endpoint-notification.service.d.ts +7 -7
  131. package/dist/src/infrastructure/notification/endpoint-notification.service.js +15 -15
  132. package/dist/src/infrastructure/notification/endpoint-notification.service.js.map +1 -1
  133. package/dist/src/infrastructure/notification/notification.module.js +2 -1
  134. package/dist/src/infrastructure/notification/notification.module.js.map +1 -1
  135. package/dist/src/utils/prisma-sql-generator/__tests__/shared-helpers.d.ts +16 -0
  136. package/dist/src/utils/prisma-sql-generator/__tests__/shared-helpers.js +70 -0
  137. package/dist/src/utils/prisma-sql-generator/__tests__/shared-helpers.js.map +1 -0
  138. package/dist/src/utils/prisma-sql-generator/__tests__/test-helpers.d.ts +52 -0
  139. package/dist/src/utils/prisma-sql-generator/__tests__/test-helpers.js +531 -0
  140. package/dist/src/utils/prisma-sql-generator/__tests__/test-helpers.js.map +1 -0
  141. package/dist/src/utils/prisma-sql-generator/index.d.ts +2 -0
  142. package/dist/src/{features/row/queries/types → utils/prisma-sql-generator}/index.js +5 -5
  143. package/dist/src/utils/prisma-sql-generator/index.js.map +1 -0
  144. package/dist/src/utils/prisma-sql-generator/json-path.d.ts +14 -0
  145. package/dist/src/utils/prisma-sql-generator/json-path.js +121 -0
  146. package/dist/src/utils/prisma-sql-generator/json-path.js.map +1 -0
  147. package/dist/src/utils/prisma-sql-generator/types.d.ts +105 -0
  148. package/dist/src/{features/row/queries/types/get-row.types.js → utils/prisma-sql-generator/types.js} +1 -1
  149. package/dist/src/utils/prisma-sql-generator/types.js.map +1 -0
  150. package/dist/src/utils/prisma-sql-generator/where-generator.prisma.d.ts +21 -0
  151. package/dist/src/utils/prisma-sql-generator/where-generator.prisma.js +499 -0
  152. package/dist/src/utils/prisma-sql-generator/where-generator.prisma.js.map +1 -0
  153. package/dist/tsconfig.build.tsbuildinfo +1 -1
  154. package/package.json +3 -1
  155. package/dist/src/__tests__/utils/createMocks.d.ts +0 -19
  156. package/dist/src/__tests__/utils/createMocks.js +0 -30
  157. package/dist/src/__tests__/utils/createMocks.js.map +0 -1
  158. package/dist/src/api/graphql-api/share/mapToPrismaOrderBy.d.ts +0 -3
  159. package/dist/src/api/graphql-api/share/mapToPrismaOrderBy.js +0 -12
  160. package/dist/src/api/graphql-api/share/mapToPrismaOrderBy.js.map +0 -1
  161. package/dist/src/api/rest-api/share/utils/mapToPrismaOrderBy.d.ts +0 -3
  162. package/dist/src/api/rest-api/share/utils/mapToPrismaOrderBy.js +0 -12
  163. package/dist/src/api/rest-api/share/utils/mapToPrismaOrderBy.js.map +0 -1
  164. package/dist/src/features/row/queries/types/get-row-by-id.types.d.ts +0 -2
  165. package/dist/src/features/row/queries/types/get-row-by-id.types.js +0 -3
  166. package/dist/src/features/row/queries/types/get-row-by-id.types.js.map +0 -1
  167. package/dist/src/features/row/queries/types/get-row.types.d.ts +0 -2
  168. package/dist/src/features/row/queries/types/get-row.types.js.map +0 -1
  169. package/dist/src/features/row/queries/types/get-rows.types.d.ts +0 -3
  170. package/dist/src/features/row/queries/types/get-rows.types.js +0 -3
  171. package/dist/src/features/row/queries/types/get-rows.types.js.map +0 -1
  172. package/dist/src/features/row/queries/types/index.d.ts +0 -5
  173. package/dist/src/features/row/queries/types/index.js.map +0 -1
  174. package/dist/src/features/row/queries/types/resolve-row-foreign-keys-by.types.d.ts +0 -3
  175. package/dist/src/features/row/queries/types/resolve-row-foreign-keys-by.types.js +0 -3
  176. package/dist/src/features/row/queries/types/resolve-row-foreign-keys-by.types.js.map +0 -1
  177. package/dist/src/features/row/queries/types/resolve-row-foreign-keys-to.types.d.ts +0 -3
  178. package/dist/src/features/row/queries/types/resolve-row-foreign-keys-to.types.js +0 -3
  179. package/dist/src/features/row/queries/types/resolve-row-foreign-keys-to.types.js.map +0 -1
  180. package/dist/src/features/table/queries/handlers/get-rows-by-table.handler.d.ts +0 -30
  181. package/dist/src/features/table/queries/handlers/get-rows-by-table.handler.js +0 -70
  182. package/dist/src/features/table/queries/handlers/get-rows-by-table.handler.js.map +0 -1
  183. package/dist/src/features/table/queries/impl/get-rows-by-table.query.d.ts +0 -21
  184. package/dist/src/features/table/queries/impl/get-rows-by-table.query.js +0 -10
  185. package/dist/src/features/table/queries/impl/get-rows-by-table.query.js.map +0 -1
@@ -0,0 +1,531 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createTableWithJsonData = createTableWithJsonData;
4
+ exports.createTableWithStringData = createTableWithStringData;
5
+ exports.createTableWithDateData = createTableWithDateData;
6
+ exports.createTableWithComplexJsonData = createTableWithComplexJsonData;
7
+ const nanoid_1 = require("nanoid");
8
+ async function createTableWithJsonData(prismaService) {
9
+ const branch = await prismaService.branch.create({
10
+ data: {
11
+ id: (0, nanoid_1.nanoid)(),
12
+ name: (0, nanoid_1.nanoid)(),
13
+ project: {
14
+ create: {
15
+ id: (0, nanoid_1.nanoid)(),
16
+ name: (0, nanoid_1.nanoid)(),
17
+ organization: {
18
+ create: {
19
+ id: (0, nanoid_1.nanoid)(),
20
+ createdId: (0, nanoid_1.nanoid)(),
21
+ },
22
+ },
23
+ },
24
+ },
25
+ },
26
+ });
27
+ const revision = await prismaService.revision.create({
28
+ data: {
29
+ id: (0, nanoid_1.nanoid)(),
30
+ branch: {
31
+ connect: {
32
+ id: branch.id,
33
+ },
34
+ },
35
+ },
36
+ });
37
+ const table = await prismaService.table.create({
38
+ data: {
39
+ id: (0, nanoid_1.nanoid)(),
40
+ createdId: (0, nanoid_1.nanoid)(),
41
+ versionId: (0, nanoid_1.nanoid)(),
42
+ revisions: {
43
+ connect: {
44
+ id: revision.id,
45
+ },
46
+ },
47
+ },
48
+ });
49
+ const testRows = [
50
+ {
51
+ id: 'json-test-1',
52
+ data: {
53
+ name: 'Alice',
54
+ age: 35,
55
+ title: 'Senior Developer',
56
+ category: 'admin',
57
+ },
58
+ meta: {},
59
+ readonly: false,
60
+ },
61
+ {
62
+ id: 'json-test-2',
63
+ data: {
64
+ name: 'Bob',
65
+ age: 25,
66
+ title: 'Developer',
67
+ category: 'user',
68
+ },
69
+ meta: {},
70
+ readonly: true,
71
+ },
72
+ {
73
+ id: 'json-test-3',
74
+ data: {
75
+ name: 'Charlie',
76
+ age: 45,
77
+ title: 'Manager',
78
+ category: 'guest',
79
+ },
80
+ meta: {},
81
+ readonly: false,
82
+ },
83
+ {
84
+ id: 'json-test-4',
85
+ data: {
86
+ name: 'David',
87
+ age: 30,
88
+ title: 'Lead Developer',
89
+ category: 'admin',
90
+ tags: ['typescript', 'react'],
91
+ },
92
+ meta: {},
93
+ readonly: false,
94
+ },
95
+ {
96
+ id: 'json-test-5',
97
+ data: {
98
+ name: 'Eve',
99
+ age: 28,
100
+ title: 'UI Designer',
101
+ category: 'user',
102
+ user: {
103
+ profile: {
104
+ name: 'Eve Profile',
105
+ age: 28,
106
+ bio: 'Senior UI/UX Designer with expertise in modern web technologies',
107
+ settings: {
108
+ theme: 'dark',
109
+ },
110
+ },
111
+ },
112
+ },
113
+ meta: {},
114
+ readonly: true,
115
+ },
116
+ ];
117
+ for (const rowData of testRows) {
118
+ await prismaService.row.create({
119
+ data: {
120
+ id: rowData.id,
121
+ createdId: (0, nanoid_1.nanoid)(),
122
+ versionId: (0, nanoid_1.nanoid)(),
123
+ readonly: rowData.readonly,
124
+ data: rowData.data,
125
+ meta: rowData.meta,
126
+ hash: (0, nanoid_1.nanoid)(),
127
+ schemaHash: (0, nanoid_1.nanoid)(),
128
+ tables: {
129
+ connect: { versionId: table.versionId },
130
+ },
131
+ },
132
+ });
133
+ }
134
+ return { table };
135
+ }
136
+ async function createTableWithStringData(prismaService) {
137
+ const branch = await prismaService.branch.create({
138
+ data: {
139
+ id: (0, nanoid_1.nanoid)(),
140
+ name: (0, nanoid_1.nanoid)(),
141
+ project: {
142
+ create: {
143
+ id: (0, nanoid_1.nanoid)(),
144
+ name: (0, nanoid_1.nanoid)(),
145
+ organization: {
146
+ create: {
147
+ id: (0, nanoid_1.nanoid)(),
148
+ createdId: (0, nanoid_1.nanoid)(),
149
+ },
150
+ },
151
+ },
152
+ },
153
+ },
154
+ });
155
+ const revision = await prismaService.revision.create({
156
+ data: {
157
+ id: (0, nanoid_1.nanoid)(),
158
+ branch: {
159
+ connect: {
160
+ id: branch.id,
161
+ },
162
+ },
163
+ },
164
+ });
165
+ const table = await prismaService.table.create({
166
+ data: {
167
+ id: (0, nanoid_1.nanoid)(),
168
+ createdId: (0, nanoid_1.nanoid)(),
169
+ versionId: (0, nanoid_1.nanoid)(),
170
+ revisions: {
171
+ connect: {
172
+ id: revision.id,
173
+ },
174
+ },
175
+ },
176
+ });
177
+ const testRows = [
178
+ {
179
+ id: 'user-1',
180
+ createdId: 'created-alpha',
181
+ hash: 'hash-special-123',
182
+ schemaHash: 'schema-SPECIAL-456',
183
+ data: { category: 'admin' },
184
+ },
185
+ {
186
+ id: 'user-2',
187
+ createdId: 'created-beta',
188
+ hash: 'hash-normal-789',
189
+ schemaHash: 'schema-normal-012',
190
+ data: { category: 'user' },
191
+ },
192
+ {
193
+ id: 'admin-1',
194
+ createdId: 'created-gamma',
195
+ hash: 'hash-SPECIAL-345',
196
+ schemaHash: 'schema-test-678',
197
+ data: { category: 'admin' },
198
+ },
199
+ ];
200
+ for (const rowData of testRows) {
201
+ await prismaService.row.create({
202
+ data: {
203
+ id: rowData.id,
204
+ createdId: rowData.createdId,
205
+ versionId: (0, nanoid_1.nanoid)(),
206
+ readonly: false,
207
+ data: rowData.data,
208
+ meta: {},
209
+ hash: rowData.hash,
210
+ schemaHash: rowData.schemaHash,
211
+ tables: {
212
+ connect: { versionId: table.versionId },
213
+ },
214
+ },
215
+ });
216
+ }
217
+ return { table };
218
+ }
219
+ async function createTableWithDateData(prismaService) {
220
+ const branch = await prismaService.branch.create({
221
+ data: {
222
+ id: (0, nanoid_1.nanoid)(),
223
+ name: (0, nanoid_1.nanoid)(),
224
+ project: {
225
+ create: {
226
+ id: (0, nanoid_1.nanoid)(),
227
+ name: (0, nanoid_1.nanoid)(),
228
+ organization: {
229
+ create: {
230
+ id: (0, nanoid_1.nanoid)(),
231
+ createdId: (0, nanoid_1.nanoid)(),
232
+ },
233
+ },
234
+ },
235
+ },
236
+ },
237
+ });
238
+ const revision = await prismaService.revision.create({
239
+ data: {
240
+ id: (0, nanoid_1.nanoid)(),
241
+ branch: {
242
+ connect: {
243
+ id: branch.id,
244
+ },
245
+ },
246
+ },
247
+ });
248
+ const table = await prismaService.table.create({
249
+ data: {
250
+ id: (0, nanoid_1.nanoid)(),
251
+ createdId: (0, nanoid_1.nanoid)(),
252
+ versionId: (0, nanoid_1.nanoid)(),
253
+ revisions: {
254
+ connect: {
255
+ id: revision.id,
256
+ },
257
+ },
258
+ },
259
+ });
260
+ const baseDate = new Date('2025-01-01T00:00:00.000Z');
261
+ const dates = [
262
+ new Date('2024-12-01T00:00:00.000Z'),
263
+ new Date('2025-01-01T00:00:00.000Z'),
264
+ new Date('2025-01-15T00:00:00.000Z'),
265
+ new Date('2025-02-01T00:00:00.000Z'),
266
+ ];
267
+ for (let i = 0; i < dates.length; i++) {
268
+ await prismaService.row.create({
269
+ data: {
270
+ id: `date-test-${i + 1}`,
271
+ createdId: (0, nanoid_1.nanoid)(),
272
+ versionId: (0, nanoid_1.nanoid)(),
273
+ readonly: false,
274
+ createdAt: dates[i],
275
+ updatedAt: dates[i],
276
+ publishedAt: dates[i],
277
+ data: { index: i },
278
+ meta: {},
279
+ hash: (0, nanoid_1.nanoid)(),
280
+ schemaHash: (0, nanoid_1.nanoid)(),
281
+ tables: {
282
+ connect: { versionId: table.versionId },
283
+ },
284
+ },
285
+ });
286
+ }
287
+ return { table, baseDate, dates };
288
+ }
289
+ async function createTableWithComplexJsonData(prismaService) {
290
+ const branch = await prismaService.branch.create({
291
+ data: {
292
+ id: (0, nanoid_1.nanoid)(),
293
+ name: (0, nanoid_1.nanoid)(),
294
+ project: {
295
+ create: {
296
+ id: (0, nanoid_1.nanoid)(),
297
+ name: (0, nanoid_1.nanoid)(),
298
+ organization: {
299
+ create: {
300
+ id: (0, nanoid_1.nanoid)(),
301
+ createdId: (0, nanoid_1.nanoid)(),
302
+ },
303
+ },
304
+ },
305
+ },
306
+ },
307
+ });
308
+ const revision = await prismaService.revision.create({
309
+ data: {
310
+ id: (0, nanoid_1.nanoid)(),
311
+ branch: {
312
+ connect: {
313
+ id: branch.id,
314
+ },
315
+ },
316
+ },
317
+ });
318
+ const table = await prismaService.table.create({
319
+ data: {
320
+ id: (0, nanoid_1.nanoid)(),
321
+ createdId: (0, nanoid_1.nanoid)(),
322
+ versionId: (0, nanoid_1.nanoid)(),
323
+ revisions: {
324
+ connect: {
325
+ id: revision.id,
326
+ },
327
+ },
328
+ },
329
+ });
330
+ const testRows = [
331
+ {
332
+ id: 'complex-1',
333
+ data: {
334
+ name: 'Alice',
335
+ category: 'admin',
336
+ priority: 1,
337
+ active: true,
338
+ score: 95.5,
339
+ createdDate: '2025-01-01T10:00:00.000Z',
340
+ lastLogin: '2025-01-15T14:30:00.000Z',
341
+ user: {
342
+ age: 35,
343
+ profile: {
344
+ name: 'Alice Profile',
345
+ settings: {
346
+ theme: 'dark',
347
+ },
348
+ },
349
+ },
350
+ tags: ['admin', 'typescript', 'react'],
351
+ products: [
352
+ { name: 'Product A', price: 99.99 },
353
+ { name: 'Product B', price: 149.5 },
354
+ ],
355
+ scores: [85, 90, 95],
356
+ reviews: [
357
+ { rating: 4.5, comment: 'Great!' },
358
+ { rating: 5.0, comment: 'Excellent!' },
359
+ ],
360
+ },
361
+ meta: {
362
+ score: 88.5,
363
+ category: 'premium',
364
+ },
365
+ readonly: false,
366
+ },
367
+ {
368
+ id: 'complex-2',
369
+ data: {
370
+ name: 'Bob',
371
+ category: 'user',
372
+ priority: 3,
373
+ active: false,
374
+ score: 78.2,
375
+ createdDate: '2024-12-15T08:30:00.000Z',
376
+ lastLogin: '2025-01-10T09:15:00.000Z',
377
+ user: {
378
+ age: 25,
379
+ profile: {
380
+ name: 'Bob Profile',
381
+ settings: {
382
+ theme: 'light',
383
+ },
384
+ },
385
+ },
386
+ tags: ['user', 'javascript', 'vue'],
387
+ products: [
388
+ { name: 'Product C', price: 79.99 },
389
+ { name: 'Product D', price: 199.0 },
390
+ ],
391
+ scores: [70, 75, 80],
392
+ reviews: [
393
+ { rating: 3.5, comment: 'Good' },
394
+ { rating: 4.0, comment: 'Nice' },
395
+ ],
396
+ },
397
+ meta: {
398
+ score: 72.8,
399
+ category: 'standard',
400
+ },
401
+ readonly: true,
402
+ },
403
+ {
404
+ id: 'complex-3',
405
+ data: {
406
+ name: 'Charlie',
407
+ category: 'guest',
408
+ priority: 2,
409
+ active: true,
410
+ score: 89.7,
411
+ createdDate: '2024-11-20T16:45:00.000Z',
412
+ lastLogin: '2025-01-20T11:00:00.000Z',
413
+ user: {
414
+ age: 42,
415
+ profile: {
416
+ name: 'Charlie Profile',
417
+ settings: {
418
+ theme: 'auto',
419
+ },
420
+ },
421
+ },
422
+ tags: ['guest', 'python', 'django'],
423
+ products: [
424
+ { name: 'Product E', price: 129.99 },
425
+ { name: 'Product F', price: 89.5 },
426
+ ],
427
+ scores: [88, 92, 87],
428
+ reviews: [
429
+ { rating: 4.8, comment: 'Amazing!' },
430
+ { rating: 4.2, comment: 'Very good!' },
431
+ ],
432
+ },
433
+ meta: {
434
+ score: 91.2,
435
+ category: 'premium',
436
+ },
437
+ readonly: false,
438
+ },
439
+ {
440
+ id: 'complex-4',
441
+ data: {
442
+ name: 'David',
443
+ category: 'admin',
444
+ priority: 1,
445
+ active: true,
446
+ score: 92.1,
447
+ createdDate: '2025-01-05T12:00:00.000Z',
448
+ lastLogin: '2025-01-18T16:45:00.000Z',
449
+ user: {
450
+ age: 31,
451
+ profile: {
452
+ name: 'David Profile',
453
+ settings: {
454
+ theme: 'dark',
455
+ },
456
+ },
457
+ },
458
+ tags: ['admin', 'nodejs', 'express'],
459
+ products: [
460
+ { name: 'Product G', price: 159.99 },
461
+ { name: 'Product H', price: 299.0 },
462
+ ],
463
+ scores: [90, 95, 89],
464
+ reviews: [
465
+ { rating: 4.9, comment: 'Outstanding!' },
466
+ { rating: 4.7, comment: 'Superb!' },
467
+ ],
468
+ },
469
+ meta: {
470
+ score: 94.8,
471
+ category: 'premium',
472
+ },
473
+ readonly: false,
474
+ },
475
+ {
476
+ id: 'complex-5',
477
+ data: {
478
+ name: 'Eve',
479
+ category: 'user',
480
+ priority: 4,
481
+ active: false,
482
+ score: 81.3,
483
+ createdDate: '2024-10-30T07:20:00.000Z',
484
+ lastLogin: '2025-01-05T13:30:00.000Z',
485
+ user: {
486
+ age: 28,
487
+ profile: {
488
+ name: 'Eve Profile',
489
+ settings: {
490
+ theme: 'light',
491
+ },
492
+ },
493
+ },
494
+ tags: ['user', 'css', 'sass'],
495
+ products: [
496
+ { name: 'Product I', price: 49.99 },
497
+ { name: 'Product J', price: 119.0 },
498
+ ],
499
+ scores: [78, 82, 85],
500
+ reviews: [
501
+ { rating: 3.8, comment: 'Pretty good' },
502
+ { rating: 4.1, comment: 'Nice work' },
503
+ ],
504
+ },
505
+ meta: {
506
+ score: 79.5,
507
+ category: 'standard',
508
+ },
509
+ readonly: true,
510
+ },
511
+ ];
512
+ for (const rowData of testRows) {
513
+ await prismaService.row.create({
514
+ data: {
515
+ id: rowData.id,
516
+ createdId: (0, nanoid_1.nanoid)(),
517
+ versionId: (0, nanoid_1.nanoid)(),
518
+ readonly: rowData.readonly,
519
+ data: rowData.data,
520
+ meta: rowData.meta,
521
+ hash: (0, nanoid_1.nanoid)(),
522
+ schemaHash: (0, nanoid_1.nanoid)(),
523
+ tables: {
524
+ connect: { versionId: table.versionId },
525
+ },
526
+ },
527
+ });
528
+ }
529
+ return { table };
530
+ }
531
+ //# sourceMappingURL=test-helpers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"test-helpers.js","sourceRoot":"","sources":["../../../../../src/utils/prisma-sql-generator/__tests__/test-helpers.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export { WhereGeneratorPrisma, generateGetRowsQueryPrisma, } from './where-generator.prisma';
2
+ export * from './types';
@@ -14,9 +14,9 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
14
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./get-row.types"), exports);
18
- __exportStar(require("./get-rows.types"), exports);
19
- __exportStar(require("./get-row-by-id.types"), exports);
20
- __exportStar(require("./resolve-row-foreign-keys-by.types"), exports);
21
- __exportStar(require("./resolve-row-foreign-keys-to.types"), exports);
17
+ exports.generateGetRowsQueryPrisma = exports.WhereGeneratorPrisma = void 0;
18
+ var where_generator_prisma_1 = require("./where-generator.prisma");
19
+ Object.defineProperty(exports, "WhereGeneratorPrisma", { enumerable: true, get: function () { return where_generator_prisma_1.WhereGeneratorPrisma; } });
20
+ Object.defineProperty(exports, "generateGetRowsQueryPrisma", { enumerable: true, get: function () { return where_generator_prisma_1.generateGetRowsQueryPrisma; } });
21
+ __exportStar(require("./types"), exports);
22
22
  //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/utils/prisma-sql-generator/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,mEAGkC;AAFhC,8HAAA,oBAAoB,OAAA;AACpB,oIAAA,0BAA0B,OAAA;AAE5B,0CAAwB"}
@@ -0,0 +1,14 @@
1
+ export type JsonValueType = 'text' | 'int' | 'float' | 'boolean' | 'timestamp';
2
+ export type JsonAggregation = 'min' | 'max' | 'avg' | 'first' | 'last';
3
+ export declare function parseJsonPath(path: string): string[];
4
+ export declare function getSqlType(type: JsonValueType | string): string;
5
+ export declare function validateJsonPath(path: string[]): void;
6
+ export declare function hasArrayWildcard(path: string | string[]): boolean;
7
+ export declare function buildJsonPathParam(path: string[]): string;
8
+ export declare function handleArrayAggregation(path: string[], aggregation: JsonAggregation): string[];
9
+ export declare function findWildcardIndex(path: string[]): number;
10
+ export declare function splitPathAtWildcard(path: string[]): {
11
+ beforeStar: string[];
12
+ afterStar: string[];
13
+ starIndex: number;
14
+ };