@rvoh/dream 2.1.0 → 2.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (183) hide show
  1. package/CHANGELOG.md +332 -0
  2. package/dist/cjs/src/helpers/cli/generateDreamContent.js +5 -4
  3. package/dist/cjs/src/helpers/cli/generateFactoryContent.js +3 -2
  4. package/dist/cjs/src/helpers/cli/generateMigrationContent.js +6 -4
  5. package/dist/cjs/src/helpers/cli/generateSerializerContent.js +1 -1
  6. package/dist/esm/src/helpers/cli/generateDreamContent.js +5 -4
  7. package/dist/esm/src/helpers/cli/generateFactoryContent.js +3 -2
  8. package/dist/esm/src/helpers/cli/generateMigrationContent.js +6 -4
  9. package/dist/esm/src/helpers/cli/generateSerializerContent.js +1 -1
  10. package/docs/classes/db.DreamMigrationHelpers.html +9 -9
  11. package/docs/classes/db.KyselyQueryDriver.html +30 -30
  12. package/docs/classes/db.PostgresQueryDriver.html +31 -31
  13. package/docs/classes/db.QueryDriverBase.html +29 -29
  14. package/docs/classes/errors.CheckConstraintViolation.html +3 -3
  15. package/docs/classes/errors.ColumnOverflow.html +3 -3
  16. package/docs/classes/errors.CreateOrFindByFailedToCreateAndFind.html +3 -3
  17. package/docs/classes/errors.DataIncompatibleWithDatabaseField.html +3 -3
  18. package/docs/classes/errors.DataTypeColumnTypeMismatch.html +3 -3
  19. package/docs/classes/errors.GlobalNameNotSet.html +3 -3
  20. package/docs/classes/errors.InvalidCalendarDate.html +2 -2
  21. package/docs/classes/errors.MissingSerializersDefinition.html +3 -3
  22. package/docs/classes/errors.NonLoadedAssociation.html +3 -3
  23. package/docs/classes/errors.NotNullViolation.html +3 -3
  24. package/docs/classes/errors.RecordNotFound.html +3 -3
  25. package/docs/classes/errors.ValidationError.html +3 -3
  26. package/docs/classes/index.CalendarDate.html +2 -2
  27. package/docs/classes/index.Decorators.html +19 -19
  28. package/docs/classes/index.Dream.html +113 -113
  29. package/docs/classes/index.DreamApp.html +5 -5
  30. package/docs/classes/index.DreamTransaction.html +2 -2
  31. package/docs/classes/index.Env.html +2 -2
  32. package/docs/classes/index.Query.html +53 -53
  33. package/docs/classes/system.CliFileWriter.html +2 -2
  34. package/docs/classes/system.DreamBin.html +2 -2
  35. package/docs/classes/system.DreamCLI.html +5 -5
  36. package/docs/classes/system.DreamImporter.html +2 -2
  37. package/docs/classes/system.DreamLogos.html +2 -2
  38. package/docs/classes/system.DreamSerializerBuilder.html +8 -8
  39. package/docs/classes/system.ObjectSerializerBuilder.html +8 -8
  40. package/docs/classes/utils.Encrypt.html +2 -2
  41. package/docs/classes/utils.Range.html +2 -2
  42. package/docs/functions/db.closeAllDbConnections.html +1 -1
  43. package/docs/functions/db.dreamDbConnections.html +1 -1
  44. package/docs/functions/db.untypedDb.html +1 -1
  45. package/docs/functions/db.validateColumn.html +1 -1
  46. package/docs/functions/db.validateTable.html +1 -1
  47. package/docs/functions/errors.pgErrorType.html +1 -1
  48. package/docs/functions/index.DreamSerializer.html +1 -1
  49. package/docs/functions/index.ObjectSerializer.html +1 -1
  50. package/docs/functions/index.ReplicaSafe.html +1 -1
  51. package/docs/functions/index.STI.html +1 -1
  52. package/docs/functions/index.SoftDelete.html +1 -1
  53. package/docs/functions/utils.camelize.html +1 -1
  54. package/docs/functions/utils.capitalize.html +1 -1
  55. package/docs/functions/utils.cloneDeepSafe.html +1 -1
  56. package/docs/functions/utils.compact.html +1 -1
  57. package/docs/functions/utils.groupBy.html +1 -1
  58. package/docs/functions/utils.hyphenize.html +1 -1
  59. package/docs/functions/utils.intersection.html +1 -1
  60. package/docs/functions/utils.isEmpty.html +1 -1
  61. package/docs/functions/utils.normalizeUnicode.html +1 -1
  62. package/docs/functions/utils.pascalize.html +1 -1
  63. package/docs/functions/utils.percent.html +1 -1
  64. package/docs/functions/utils.range-1.html +1 -1
  65. package/docs/functions/utils.round.html +1 -1
  66. package/docs/functions/utils.sanitizeString.html +1 -1
  67. package/docs/functions/utils.snakeify.html +1 -1
  68. package/docs/functions/utils.sort.html +1 -1
  69. package/docs/functions/utils.sortBy.html +1 -1
  70. package/docs/functions/utils.sortObjectByKey.html +1 -1
  71. package/docs/functions/utils.sortObjectByValue.html +1 -1
  72. package/docs/functions/utils.uncapitalize.html +1 -1
  73. package/docs/functions/utils.uniq.html +1 -1
  74. package/docs/interfaces/openapi.OpenapiDescription.html +2 -2
  75. package/docs/interfaces/openapi.OpenapiSchemaProperties.html +1 -1
  76. package/docs/interfaces/openapi.OpenapiSchemaPropertiesShorthand.html +1 -1
  77. package/docs/interfaces/openapi.OpenapiTypeFieldObject.html +1 -1
  78. package/docs/interfaces/types.BelongsToStatement.html +2 -2
  79. package/docs/interfaces/types.DecoratorContext.html +2 -2
  80. package/docs/interfaces/types.DreamAppInitOptions.html +2 -2
  81. package/docs/interfaces/types.DreamAppOpts.html +2 -2
  82. package/docs/interfaces/types.EncryptOptions.html +2 -2
  83. package/docs/interfaces/types.InternalAnyTypedSerializerRendersMany.html +2 -2
  84. package/docs/interfaces/types.InternalAnyTypedSerializerRendersOne.html +2 -2
  85. package/docs/interfaces/types.SerializerRendererOpts.html +2 -2
  86. package/docs/modules/db.html +1 -1
  87. package/docs/modules/errors.html +1 -1
  88. package/docs/modules/index.html +1 -1
  89. package/docs/modules/openapi.html +1 -1
  90. package/docs/modules/system.html +1 -1
  91. package/docs/modules/types.html +1 -1
  92. package/docs/modules/utils.html +1 -1
  93. package/docs/types/index.DateTime.html +1 -1
  94. package/docs/types/openapi.CommonOpenapiSchemaObjectFields.html +1 -1
  95. package/docs/types/openapi.OpenapiAllTypes.html +1 -1
  96. package/docs/types/openapi.OpenapiFormats.html +1 -1
  97. package/docs/types/openapi.OpenapiNumberFormats.html +1 -1
  98. package/docs/types/openapi.OpenapiPrimitiveBaseTypes.html +1 -1
  99. package/docs/types/openapi.OpenapiPrimitiveTypes.html +1 -1
  100. package/docs/types/openapi.OpenapiSchemaArray.html +1 -1
  101. package/docs/types/openapi.OpenapiSchemaArrayShorthand.html +1 -1
  102. package/docs/types/openapi.OpenapiSchemaBase.html +1 -1
  103. package/docs/types/openapi.OpenapiSchemaBody.html +1 -1
  104. package/docs/types/openapi.OpenapiSchemaBodyShorthand.html +1 -1
  105. package/docs/types/openapi.OpenapiSchemaCommonFields.html +1 -1
  106. package/docs/types/openapi.OpenapiSchemaExpressionAllOf.html +1 -1
  107. package/docs/types/openapi.OpenapiSchemaExpressionAnyOf.html +1 -1
  108. package/docs/types/openapi.OpenapiSchemaExpressionOneOf.html +1 -1
  109. package/docs/types/openapi.OpenapiSchemaExpressionRef.html +1 -1
  110. package/docs/types/openapi.OpenapiSchemaExpressionRefSchemaShorthand.html +1 -1
  111. package/docs/types/openapi.OpenapiSchemaInteger.html +1 -1
  112. package/docs/types/openapi.OpenapiSchemaNull.html +1 -1
  113. package/docs/types/openapi.OpenapiSchemaNumber.html +1 -1
  114. package/docs/types/openapi.OpenapiSchemaObject.html +1 -1
  115. package/docs/types/openapi.OpenapiSchemaObjectAllOf.html +1 -1
  116. package/docs/types/openapi.OpenapiSchemaObjectAllOfShorthand.html +1 -1
  117. package/docs/types/openapi.OpenapiSchemaObjectAnyOf.html +1 -1
  118. package/docs/types/openapi.OpenapiSchemaObjectAnyOfShorthand.html +1 -1
  119. package/docs/types/openapi.OpenapiSchemaObjectBase.html +1 -1
  120. package/docs/types/openapi.OpenapiSchemaObjectBaseShorthand.html +1 -1
  121. package/docs/types/openapi.OpenapiSchemaObjectOneOf.html +1 -1
  122. package/docs/types/openapi.OpenapiSchemaObjectOneOfShorthand.html +1 -1
  123. package/docs/types/openapi.OpenapiSchemaObjectShorthand.html +1 -1
  124. package/docs/types/openapi.OpenapiSchemaPrimitiveGeneric.html +1 -1
  125. package/docs/types/openapi.OpenapiSchemaShorthandExpressionAllOf.html +1 -1
  126. package/docs/types/openapi.OpenapiSchemaShorthandExpressionAnyOf.html +1 -1
  127. package/docs/types/openapi.OpenapiSchemaShorthandExpressionOneOf.html +1 -1
  128. package/docs/types/openapi.OpenapiSchemaShorthandExpressionSerializableRef.html +1 -1
  129. package/docs/types/openapi.OpenapiSchemaShorthandExpressionSerializerRef.html +1 -1
  130. package/docs/types/openapi.OpenapiSchemaShorthandPrimitiveGeneric.html +1 -1
  131. package/docs/types/openapi.OpenapiSchemaString.html +1 -1
  132. package/docs/types/openapi.OpenapiShorthandAllTypes.html +1 -1
  133. package/docs/types/openapi.OpenapiShorthandPrimitiveBaseTypes.html +1 -1
  134. package/docs/types/openapi.OpenapiShorthandPrimitiveTypes.html +1 -1
  135. package/docs/types/openapi.OpenapiTypeField.html +1 -1
  136. package/docs/types/system.DreamAppAllowedPackageManagersEnum.html +1 -1
  137. package/docs/types/types.Camelized.html +1 -1
  138. package/docs/types/types.DbConnectionType.html +1 -1
  139. package/docs/types/types.DbTypes.html +1 -1
  140. package/docs/types/types.DreamAssociationMetadata.html +1 -1
  141. package/docs/types/types.DreamAttributes.html +1 -1
  142. package/docs/types/types.DreamClassAssociationAndStatement.html +1 -1
  143. package/docs/types/types.DreamClassColumn.html +1 -1
  144. package/docs/types/types.DreamColumn.html +1 -1
  145. package/docs/types/types.DreamColumnNames.html +1 -1
  146. package/docs/types/types.DreamLogLevel.html +1 -1
  147. package/docs/types/types.DreamLogger.html +1 -1
  148. package/docs/types/types.DreamModelSerializerType.html +1 -1
  149. package/docs/types/types.DreamOrViewModelClassSerializerKey.html +1 -1
  150. package/docs/types/types.DreamOrViewModelSerializerKey.html +1 -1
  151. package/docs/types/types.DreamParamSafeAttributes.html +1 -1
  152. package/docs/types/types.DreamParamSafeColumnNames.html +1 -1
  153. package/docs/types/types.DreamSerializable.html +1 -1
  154. package/docs/types/types.DreamSerializableArray.html +1 -1
  155. package/docs/types/types.DreamSerializerKey.html +1 -1
  156. package/docs/types/types.DreamSerializers.html +1 -1
  157. package/docs/types/types.DreamVirtualColumns.html +1 -1
  158. package/docs/types/types.EncryptAlgorithm.html +1 -1
  159. package/docs/types/types.HasManyStatement.html +1 -1
  160. package/docs/types/types.HasOneStatement.html +1 -1
  161. package/docs/types/types.Hyphenized.html +1 -1
  162. package/docs/types/types.Pascalized.html +1 -1
  163. package/docs/types/types.RoundingPrecision.html +1 -1
  164. package/docs/types/types.SerializerCasing.html +1 -1
  165. package/docs/types/types.SimpleObjectSerializerType.html +1 -1
  166. package/docs/types/types.Snakeified.html +1 -1
  167. package/docs/types/types.StrictInterface.html +1 -1
  168. package/docs/types/types.UpdateableAssociationProperties.html +1 -1
  169. package/docs/types/types.UpdateableProperties.html +1 -1
  170. package/docs/types/types.ValidationType.html +1 -1
  171. package/docs/types/types.ViewModel.html +1 -1
  172. package/docs/types/types.ViewModelClass.html +1 -1
  173. package/docs/types/types.WhereStatementForDream.html +1 -1
  174. package/docs/types/types.WhereStatementForDreamClass.html +1 -1
  175. package/docs/variables/index.DateTime-1.html +1 -1
  176. package/docs/variables/index.DreamConst.html +1 -1
  177. package/docs/variables/index.ops.html +1 -1
  178. package/docs/variables/openapi.openapiPrimitiveTypes-1.html +1 -1
  179. package/docs/variables/openapi.openapiShorthandPrimitiveTypes-1.html +1 -1
  180. package/docs/variables/system.DreamAppAllowedPackageManagersEnumValues.html +1 -1
  181. package/docs/variables/types.TRIGRAM_OPERATORS.html +1 -1
  182. package/docs/variables/types.primaryKeyTypes.html +1 -1
  183. package/package.json +7 -3
package/CHANGELOG.md ADDED
@@ -0,0 +1,332 @@
1
+ ## 2.1.2
2
+
3
+ - add missing peerDependencies
4
+
5
+ ## 2.1.1
6
+
7
+ generators support alternate casings when parsing association statements (i.e. `psy g model Pet user:belongsTo`)
8
+
9
+ ## 2.1.0
10
+
11
+ - Change type file generation to AST
12
+ - Soft-deprecate DBClass (automatically updated on sync)
13
+
14
+ ## 2.0.4
15
+
16
+ improve CLI command descriptions
17
+
18
+ ## 2.0.3
19
+
20
+ don't require database to exist when creating migrations (fixes create-psychic with uuid primary keys)
21
+
22
+ ## 2.0.2
23
+
24
+ bump glob to close dependabot alerts
25
+
26
+ ## 2.0.1
27
+
28
+ remove dream-spec-helpers from peer dependencies
29
+
30
+ ## 2.0.0
31
+
32
+ - namespace package exports
33
+ - remove `Benchmark`
34
+ - Remove `leftJoinPreloadFor` and `leftJoinLoadFor`. They were never a good idea since the idea of `preloadFor` is that one doesn't need to pay attention to all the things that need to be preloaded, but in a join situation, this is a recipe for disaster since loading tables in parallel results in a Cartesian product of result rows being
35
+
36
+ ## 1.13.0
37
+
38
+ - generated code uses absolute imports
39
+ - `Virtual` decorator requires OpenAPI shape
40
+ - don't let a null value in a `Sortable` column break future sorts (null may enter via a migration or `skipHooks`)
41
+ - simplify and DRY up Sortable
42
+ - Sortable keeps values within the range 1 to N
43
+ - fix STI child generation with array attributes (arrays can always be initialized to an empty array, so can leverage a regular non-null constraint). E.g:
44
+
45
+ ```
46
+ yarn psy g:sti-child Room/Bedroom extends Room bed_types:enum\[\]:bed_types:twin,bunk,queen,king,cot,sofabed
47
+ ```
48
+
49
+ ## 1.12.0
50
+
51
+ - DateTime and CalendarDate are always valid and throw an error if invalid
52
+
53
+ ## 1.11.0
54
+
55
+ - fix `scrollPaginate` when the column being ordered by is not unique
56
+ - fix `pluck` so it properly omits soft-deleted records
57
+
58
+ ## 1.11.0
59
+
60
+ - `association` and `associationOrFail` handle required and passthrough `and` clauses
61
+ - `association` and `associationOrFail` compatible with transactions
62
+ - `scrollPaginate` Query and static Dream methods
63
+ - remove `paginate` from DreamClassTransactionBuilder
64
+
65
+ ## 1.10.0
66
+
67
+ - bump kysely
68
+ - paginate includes default ordering on id
69
+ - cli command to ensure migrations have been run prior to running specs
70
+ - fix ability to sync when type files don't reflect models
71
+ - leverage Map instead of an object so don't need to prefix numeric keys with underscore to prevent them from being sorted by numeric value rather than by the order in which they were added to the map
72
+ - renameTable migration helper
73
+ - the key function passed to `sortBy` may now also return a DateTime, a CalendarDate, or a bigint
74
+ - fix `sort` on bigint arrays
75
+ - `percent` function
76
+ - `association` and `associationOrFail` methods to encapsulate the loaded check or associationQuery ternary pattern
77
+ - generated association name and id for a `belongs_to` association are based on the final part of the model name, not the entire namespace [requires Psychic update for generated resource controllers/specs to generate valid code]
78
+ - [BREAKING] `on` replaces `foreignKey` in association declarations, e.g.:
79
+
80
+ ```
81
+ @deco.HasOne('BalloonLine', { on: 'balloonId' })
82
+ public balloonLine: BalloonLine
83
+ ```
84
+
85
+ - generated migrations include index on foreign key
86
+ - don't require openapi for delegatedType when delegating to an association since we can derive the openapi type automatically [requires Psychic update for proper OpenAPI shape to be generated]
87
+ - fix OpenAPI in generated STI base serializer
88
+
89
+ ## 1.9.4
90
+
91
+ - if `required: false`, leave the property undefined rather than rendering as `null`
92
+
93
+ ## 1.9.3
94
+
95
+ - serializer builder attribute option types allow `required: false`; this will be used by Psychic to omit attributes from the required array in OpenaAPI
96
+
97
+ ## 1.9.2
98
+
99
+ - allow null for ops argument to a where clause on a datetime or date column
100
+
101
+ ## 1.9.1
102
+
103
+ - fix where clause range types to allow mixing of CalendarDate and DateTime between start and end of range
104
+ - DateTime and CalendarDate may be used in ops when comparing against a date or datetime column
105
+
106
+ ## 1.9.0
107
+
108
+ Fix broken param safe type columns so that:
109
+
110
+ 1. polymorphic type fields are excluded from param safe types
111
+ 2. association names are excluded
112
+
113
+ Bumping minor, since it could introduce breaking changes for those reliant on previous param safe behavior.
114
+
115
+ ## 1.8.0
116
+
117
+ - throw ColumnOverflow when saving too long a string / number to a database column
118
+ - make all of these errors extend the same error so Psychic can check a single error type when deciding to return 400
119
+
120
+ ## 1.7.3
121
+
122
+ - remove unnecessary token, now that we are open-sourced
123
+
124
+ ## 1.7.2
125
+
126
+ - fix issue causing generators to generate invalid uuid primary keys
127
+
128
+ ## 1.7.1
129
+
130
+ - fix error when file without default export exists in the models directory hierarchy
131
+
132
+ ## 1.7.0
133
+
134
+ - Remove `Dream#isDreamInstance` and `DreamSerializerBuilder/ObjectSerializerBuilder#isSerializer`
135
+ - Export `MissingSerializersDefinition`
136
+
137
+ ## 1.6.0
138
+
139
+ - Move sanitization to Psychic so it can sanitize to real unicode representations
140
+
141
+ ## 1.5.2
142
+
143
+ - Don't require `openapi` for virtual attributes
144
+ - Fix Sortable with null value in scope column
145
+ - Enable sanitization of serialized attributes
146
+ - Enable `<association>.<column>: null` where statements even when the column can't be null so that queries can be constructed to locate models that don't have a particular association
147
+
148
+ ## 1.5.1
149
+
150
+ Add `DreamMigrationHelpers.newTransaction()` to support explicitly starting a new transaction within a migration.
151
+
152
+ ## 1.5.0
153
+
154
+ - add support for multiple database connections in a single dream application. To take advantage of this new feature, you can do the following:
155
+
156
+ 1. Add a new connection configuration to your conf/dream.ts file, providing it an explicit alternate connection name as the second argument, like so:
157
+
158
+ ```ts
159
+ dreamApp.set('db', 'myAlternateConnection', {
160
+ primary: {
161
+ user: AppEnv.string('DB_USER'),
162
+ password: AppEnv.string('DB_PASSWORD', { optional: !AppEnv.isProduction }),
163
+ host: AppEnv.string('DB_HOST', { optional: true }),
164
+ name: AppEnv.string('ALTERNATE_DB_NAME', { optional: true }),
165
+ port: AppEnv.integer('ALTERNATE_DB_PORT', { optional: true }),
166
+ useSsl: false,
167
+ },
168
+ })
169
+ ```
170
+
171
+ Be sure to add any new environment variables to your .env and .env.test files.
172
+
173
+ 2. Run sync
174
+
175
+ ```sh
176
+ yarn psy sync
177
+ ```
178
+
179
+ 3. add a new application model for your new connection, naming it the name of your connection, pascalized, with the string `ApplicationModel` at the end, like so:
180
+
181
+ ```ts
182
+ // app/models/MyAlternateConnectionApplicationModel.ts
183
+
184
+ import Dream from '../../../src/Dream.js'
185
+ import { DBClass } from '../../types/db.alternateConnection.js'
186
+ import { connectionTypeConfig, schema } from '../../types/dream.alternateConnection.js'
187
+ import { globalTypeConfig } from '../../types/dream.globals.js'
188
+
189
+ export default class MyAlternateConnectionApplicationModel extends Dream {
190
+ declare public DB: DBClass
191
+
192
+ public override get connectionName() {
193
+ return 'alternateConnection' as const
194
+ }
195
+
196
+ public override get schema(): any {
197
+ return schema
198
+ }
199
+
200
+ public override get connectionTypeConfig() {
201
+ return connectionTypeConfig
202
+ }
203
+
204
+ public override get globalTypeConfig() {
205
+ return globalTypeConfig
206
+ }
207
+ }
208
+ ```
209
+
210
+ 4. Now you can proceed to generate a model for your new connection, like so:
211
+
212
+ ```sh
213
+ yarn psy g:model MyNewModel someField:text --connection-name=myAlternateConnection
214
+ ```
215
+
216
+ Dream will automatically read the connectionName and use it to derive the `MyAlternateConnectionApplicationModel` automatically, though if this isn't correct, you will need to manually adjust it.
217
+
218
+ 5. Alternate db engine support
219
+
220
+ If you would like to use an alternate db engine, this is also now supported. To do this, you will need to provide a query driver class that extends one of our base query driver classes. As an example, I recommend you take a look at the `MysqlQueryDriver.ts` file housed within the test-app folder of this repo. This class is not ready for production use, but is a good jumping off point for those interested in supporting a different query driver for dream.
221
+
222
+ To utilize this feature, simply provide a different query driver class in your db connection config, like so:
223
+
224
+ ```ts
225
+ // conf/dream.ts
226
+
227
+ app.set('db', {
228
+ queryDriverClass: MyCustomQueryDriverClass,
229
+ ...
230
+ })
231
+ ```
232
+
233
+ ## 1.4.2
234
+
235
+ - add ability to set custom import extension, which will be used when generating new files for your application
236
+
237
+ ## 1.4.1
238
+
239
+ - cache Dream app earlier in the initialization sequence
240
+
241
+ ## 1.4.0
242
+
243
+ - fix `preloadFor` infinite loop when serializers have circular references
244
+
245
+ - generated STI base serializer updated to only include the single type of the particular STI child in the OpenAPI shape for that child
246
+
247
+ - change `primaryKeyValue` from a getter to a method so it can return the correct type even when `primaryKey` has been overridden on a particular Dream model
248
+
249
+ - remove `IdType`, an unnecessary abstraction that caused type inconsistencies
250
+
251
+ - explicitly handle bigint from the database as string
252
+
253
+ ## 1.3.3
254
+
255
+ - make `referenceTypeString` public
256
+
257
+ ## 1.3.2
258
+
259
+ - restore aliasing in preload/load queries
260
+
261
+ ## 1.3.1
262
+
263
+ - throw NotNullViolation when Postgres throws a not null violation
264
+
265
+ - throw CheckViolation when Postgres throws a check violation
266
+
267
+ ## 1.3.0
268
+
269
+ - sti-child generator includes check constraint instead of not-null since the column should only be not-null for that STI child (or modified by hand to accommodate more than one STI child)
270
+
271
+ - add `Dream#hasAssociation`
272
+
273
+ - fix preloading associations on other side of a polyorphic belongs-to association so that we don't set an association on a dream model that doesn't define that association
274
+
275
+ - fix preloading association on the other side of a polymorphic belongs-to since the same association name may be defined differently on different models. For example, taskable may be a Chore or a Workout, both of which have an `images` association, but `images` goes through ChoreImage on Chore and through WorkoutImage on Workout
276
+
277
+ - fix preloadFor when a rendersOne/Many renders a polymorphic belongs-to (was only preloading serializer associations for one of the polymorphically associated models)
278
+
279
+ - fix preloadFor when an explicit serializer option is provided to a rendersOne/Many
280
+
281
+ ## 1.2.1
282
+
283
+ - Throw DataTypeColumnTypeMismatch when Postgres throws an error attempting to save to a column with a value that can't be cast to the column type.
284
+
285
+ ## 1.2.0
286
+
287
+ - Add Dream.lookup, enabling devs to tap into the IOC provided by dream to dodge circular import issues
288
+
289
+ ## 1.1.2
290
+
291
+ - CliFileWriter does not raise error if the file we are writing is not in the file system yet.
292
+
293
+ ## 1.1.1
294
+
295
+ - Add fs.writeFile options as third argument to CliFileWriter.write, enabling psychic to provide custom flags when writing openapi.json files.
296
+
297
+ ## 1.1.0
298
+
299
+ - Remove support for preloadThroughColumns. They were broken, fixing them would be overly complex, and the same effect can be obtained using flatten on a serializer rendersOne
300
+
301
+ ## 1.0.6
302
+
303
+ - Fix joining after a through a polymorphic BelongsTo
304
+ association.
305
+
306
+ - Improve join implementation
307
+
308
+ - Disable leftJoinPreload preloadThroughColumns since it doesn't actually work on through associations that resolve to a source that doesn't match the association name (and we were unnecessarily including columns in the leftJoinPreload statement even when there was no `preloadThroughColumns`, thereby bloating the queries unnecessarily)
309
+
310
+ ## 1.0.5
311
+
312
+ - Support HasOne/Many through polymorphic BelongsTo (trick is that it uses the associated model from the HasOne/Many to limit the BelongsTo to a single associated class / table)
313
+
314
+ - Fix HasOne/Many through source type
315
+
316
+ - sync process is now fail-safe, leveraging a utility which caches old copies of files before writing to them. If an exception is thrown at any point during the process, dream will revert all files written using the new `CliFileWriter` class
317
+
318
+ ## 1.0.4
319
+
320
+ - properly exclude type from `DreamParamSafeColumnNames`
321
+
322
+ ## 1.0.3
323
+
324
+ - exclude type from `DreamParamSafeColumnNames`
325
+
326
+ ## 1.0.2
327
+
328
+ - stop computing foreign keys in schema builder when building schema for through associations
329
+
330
+ ## 1.0.1
331
+
332
+ - [bug] fix preloading STI model via polymporhic association (polymorphic type was being altered to the STI child rather than left as the STI base)
@@ -94,11 +94,12 @@ export function processAttribute(attribute, modelClassName) {
94
94
  if (!attributeType) {
95
95
  throw new Error(`must pass a column type for ${attributeName} (i.e. ${attributeName}:string)`);
96
96
  }
97
- switch (attributeType) {
98
- case 'belongs_to':
97
+ const processedAttrType = camelize(attributeType).toLowerCase();
98
+ switch (processedAttrType) {
99
+ case 'belongsto':
99
100
  return createBelongsToAttribute(attributeName, descriptors, modelClassName);
100
- case 'has_one':
101
- case 'has_many':
101
+ case 'hasone':
102
+ case 'hasmany':
102
103
  return { content: '', imports: [] };
103
104
  case 'encrypted':
104
105
  return createEncryptedAttribute(attributeName, attribute, modelClassName);
@@ -30,8 +30,9 @@ export default function generateFactoryContent({ fullyQualifiedModelName, column
30
30
  continue;
31
31
  if (!attributeType)
32
32
  throw new Error(`Must pass a column type for ${attributeName} (i.e. ${attributeName}:string)`);
33
- switch (attributeType) {
34
- case 'belongs_to': {
33
+ const safeAttributeType = camelize(attributeType)?.toLowerCase();
34
+ switch (safeAttributeType) {
35
+ case 'belongsto': {
35
36
  const attributeVariable = camelize(attributeName.split('/').pop());
36
37
  const fullyQualifiedAssociatedModelName = standardizeFullyQualifiedModelName(attributeName);
37
38
  const associationModelName = globalClassNameFromFullyQualifiedModelName(fullyQualifiedAssociatedModelName);
@@ -3,6 +3,7 @@ import Query from '../../dream/Query.js';
3
3
  import InvalidDecimalFieldPassedToGenerator from '../../errors/InvalidDecimalFieldPassedToGenerator.js';
4
4
  import compact from '../compact.js';
5
5
  import snakeify from '../snakeify.js';
6
+ import camelize from '../camelize.js';
6
7
  const STI_TYPE_COLUMN_NAME = 'type';
7
8
  const COLUMNS_TO_INDEX = [STI_TYPE_COLUMN_NAME];
8
9
  export default function generateMigrationContent({ connectionName = 'default', table, columnsWithTypes = [], primaryKeyType = 'bigserial', createOrAlter = 'create', stiChildClassName, } = {}) {
@@ -17,11 +18,12 @@ export default function generateMigrationContent({ connectionName = 'default', t
17
18
  * email address are the same email address
18
19
  */
19
20
  const attributeType = nonStandardAttributeName === 'email' ? 'citext' : _attributeType;
21
+ const processedAttrType = camelize(attributeType)?.toLowerCase();
20
22
  const userWantsThisOptional = optionalFromDescriptors(descriptors);
21
23
  // when creating a migration for an STI child, we don't want to include notNull;
22
24
  // instead, we'll add a check constraint that uses the STI child class name
23
25
  const sqlAttributeType = getAttributeType(attributeType, descriptors);
24
- if (attributeType === undefined || ['has_one', 'has_many'].includes(attributeType))
26
+ if (attributeType === undefined || ['hasone', 'hasmany'].includes(processedAttrType))
25
27
  return acc;
26
28
  if (attributeType === 'citext')
27
29
  requireCitextExtension = true;
@@ -30,8 +32,8 @@ export default function generateMigrationContent({ connectionName = 'default', t
30
32
  if (nonStandardAttributeName === undefined)
31
33
  return acc;
32
34
  let attributeName = snakeify(nonStandardAttributeName);
33
- switch (attributeType) {
34
- case 'belongs_to':
35
+ switch (processedAttrType) {
36
+ case 'belongsto':
35
37
  columnDefs.push(generateBelongsToStr(connectionName, attributeName, {
36
38
  primaryKeyType,
37
39
  omitInlineNonNull,
@@ -82,7 +84,7 @@ export default function generateMigrationContent({ connectionName = 'default', t
82
84
  break;
83
85
  }
84
86
  columnDrops.push(`.dropColumn('${attributeName}')`);
85
- if (attributeType === 'belongs_to' || COLUMNS_TO_INDEX.includes(attributeName)) {
87
+ if (processedAttrType === 'belongsto' || COLUMNS_TO_INDEX.includes(attributeName)) {
86
88
  const indexName = `${table}_${attributeName}`;
87
89
  indexDefs.push(`await db.schema
88
90
  .createIndex('${indexName}')
@@ -49,7 +49,7 @@ export default function generateSerializerContent({ fullyQualifiedModelName, col
49
49
  const [name, type] = attr.split(':');
50
50
  if (name === undefined)
51
51
  return '';
52
- if (['belongs_to', 'has_one', 'has_many'].includes(type))
52
+ if (['belongsto', 'hasone', 'hasmany'].includes(camelize(type)?.toLowerCase()))
53
53
  return '';
54
54
  return `\n ${attribute(modelClassName, name, type, attr, stiBaseSerializer)}`;
55
55
  })
@@ -94,11 +94,12 @@ export function processAttribute(attribute, modelClassName) {
94
94
  if (!attributeType) {
95
95
  throw new Error(`must pass a column type for ${attributeName} (i.e. ${attributeName}:string)`);
96
96
  }
97
- switch (attributeType) {
98
- case 'belongs_to':
97
+ const processedAttrType = camelize(attributeType).toLowerCase();
98
+ switch (processedAttrType) {
99
+ case 'belongsto':
99
100
  return createBelongsToAttribute(attributeName, descriptors, modelClassName);
100
- case 'has_one':
101
- case 'has_many':
101
+ case 'hasone':
102
+ case 'hasmany':
102
103
  return { content: '', imports: [] };
103
104
  case 'encrypted':
104
105
  return createEncryptedAttribute(attributeName, attribute, modelClassName);
@@ -30,8 +30,9 @@ export default function generateFactoryContent({ fullyQualifiedModelName, column
30
30
  continue;
31
31
  if (!attributeType)
32
32
  throw new Error(`Must pass a column type for ${attributeName} (i.e. ${attributeName}:string)`);
33
- switch (attributeType) {
34
- case 'belongs_to': {
33
+ const safeAttributeType = camelize(attributeType)?.toLowerCase();
34
+ switch (safeAttributeType) {
35
+ case 'belongsto': {
35
36
  const attributeVariable = camelize(attributeName.split('/').pop());
36
37
  const fullyQualifiedAssociatedModelName = standardizeFullyQualifiedModelName(attributeName);
37
38
  const associationModelName = globalClassNameFromFullyQualifiedModelName(fullyQualifiedAssociatedModelName);
@@ -3,6 +3,7 @@ import Query from '../../dream/Query.js';
3
3
  import InvalidDecimalFieldPassedToGenerator from '../../errors/InvalidDecimalFieldPassedToGenerator.js';
4
4
  import compact from '../compact.js';
5
5
  import snakeify from '../snakeify.js';
6
+ import camelize from '../camelize.js';
6
7
  const STI_TYPE_COLUMN_NAME = 'type';
7
8
  const COLUMNS_TO_INDEX = [STI_TYPE_COLUMN_NAME];
8
9
  export default function generateMigrationContent({ connectionName = 'default', table, columnsWithTypes = [], primaryKeyType = 'bigserial', createOrAlter = 'create', stiChildClassName, } = {}) {
@@ -17,11 +18,12 @@ export default function generateMigrationContent({ connectionName = 'default', t
17
18
  * email address are the same email address
18
19
  */
19
20
  const attributeType = nonStandardAttributeName === 'email' ? 'citext' : _attributeType;
21
+ const processedAttrType = camelize(attributeType)?.toLowerCase();
20
22
  const userWantsThisOptional = optionalFromDescriptors(descriptors);
21
23
  // when creating a migration for an STI child, we don't want to include notNull;
22
24
  // instead, we'll add a check constraint that uses the STI child class name
23
25
  const sqlAttributeType = getAttributeType(attributeType, descriptors);
24
- if (attributeType === undefined || ['has_one', 'has_many'].includes(attributeType))
26
+ if (attributeType === undefined || ['hasone', 'hasmany'].includes(processedAttrType))
25
27
  return acc;
26
28
  if (attributeType === 'citext')
27
29
  requireCitextExtension = true;
@@ -30,8 +32,8 @@ export default function generateMigrationContent({ connectionName = 'default', t
30
32
  if (nonStandardAttributeName === undefined)
31
33
  return acc;
32
34
  let attributeName = snakeify(nonStandardAttributeName);
33
- switch (attributeType) {
34
- case 'belongs_to':
35
+ switch (processedAttrType) {
36
+ case 'belongsto':
35
37
  columnDefs.push(generateBelongsToStr(connectionName, attributeName, {
36
38
  primaryKeyType,
37
39
  omitInlineNonNull,
@@ -82,7 +84,7 @@ export default function generateMigrationContent({ connectionName = 'default', t
82
84
  break;
83
85
  }
84
86
  columnDrops.push(`.dropColumn('${attributeName}')`);
85
- if (attributeType === 'belongs_to' || COLUMNS_TO_INDEX.includes(attributeName)) {
87
+ if (processedAttrType === 'belongsto' || COLUMNS_TO_INDEX.includes(attributeName)) {
86
88
  const indexName = `${table}_${attributeName}`;
87
89
  indexDefs.push(`await db.schema
88
90
  .createIndex('${indexName}')
@@ -49,7 +49,7 @@ export default function generateSerializerContent({ fullyQualifiedModelName, col
49
49
  const [name, type] = attr.split(':');
50
50
  if (name === undefined)
51
51
  return '';
52
- if (['belongs_to', 'has_one', 'has_many'].includes(type))
52
+ if (['belongsto', 'hasone', 'hasmany'].includes(camelize(type)?.toLowerCase()))
53
53
  return '';
54
54
  return `\n ${attribute(modelClassName, name, type, attr, stiBaseSerializer)}`;
55
55
  })