typeorm 0.2.42-dev.f3e2b0e → 0.2.42-dev.f7c1f7d

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 (366) hide show
  1. package/README.md +38 -0
  2. package/browser/cache/RedisQueryResultCache.js +40 -35
  3. package/browser/cache/RedisQueryResultCache.js.map +1 -1
  4. package/browser/common/RelationType.d.ts +14 -0
  5. package/browser/common/RelationType.js +3 -0
  6. package/browser/common/RelationType.js.map +1 -0
  7. package/browser/connection/BaseConnectionOptions.d.ts +5 -0
  8. package/browser/connection/BaseConnectionOptions.js.map +1 -1
  9. package/browser/connection/Connection.d.ts +7 -3
  10. package/browser/connection/Connection.js +47 -31
  11. package/browser/connection/Connection.js.map +1 -1
  12. package/browser/connection/ConnectionMetadataBuilder.d.ts +3 -3
  13. package/browser/connection/ConnectionMetadataBuilder.js +54 -22
  14. package/browser/connection/ConnectionMetadataBuilder.js.map +1 -1
  15. package/browser/connection/ConnectionOptionsReader.js +33 -28
  16. package/browser/connection/ConnectionOptionsReader.js.map +1 -1
  17. package/browser/connection/options-reader/ConnectionOptionsEnvReader.js +1 -0
  18. package/browser/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
  19. package/browser/decorator/Unique.d.ts +5 -4
  20. package/browser/decorator/Unique.js +7 -3
  21. package/browser/decorator/Unique.js.map +1 -1
  22. package/browser/decorator/columns/PrimaryGeneratedColumn.d.ts +2 -1
  23. package/browser/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
  24. package/browser/decorator/options/ColumnOptions.d.ts +4 -0
  25. package/browser/decorator/options/ColumnOptions.js.map +1 -1
  26. package/browser/decorator/options/PrimaryGeneratedColumnIdentityOptions.d.ts +22 -0
  27. package/browser/decorator/options/PrimaryGeneratedColumnIdentityOptions.js +3 -0
  28. package/browser/decorator/options/PrimaryGeneratedColumnIdentityOptions.js.map +1 -0
  29. package/browser/decorator/options/RelationOptions.d.ts +1 -1
  30. package/browser/decorator/options/RelationOptions.js.map +1 -1
  31. package/browser/decorator/options/UniqueOptions.d.ts +10 -0
  32. package/browser/decorator/options/UniqueOptions.js +3 -0
  33. package/browser/decorator/options/UniqueOptions.js.map +1 -0
  34. package/browser/driver/aurora-data-api/AuroraDataApiQueryRunner.js +2 -2
  35. package/browser/driver/aurora-data-api/AuroraDataApiQueryRunner.js.map +1 -1
  36. package/browser/driver/better-sqlite3/BetterSqlite3Driver.js +7 -5
  37. package/browser/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -1
  38. package/browser/driver/cockroachdb/CockroachQueryRunner.js +1 -1
  39. package/browser/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  40. package/browser/driver/mongodb/MongoConnectionOptions.d.ts +1 -1
  41. package/browser/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  42. package/browser/driver/mysql/MysqlQueryRunner.js +1 -1
  43. package/browser/driver/mysql/MysqlQueryRunner.js.map +1 -1
  44. package/browser/driver/oracle/OracleQueryRunner.js +1 -1
  45. package/browser/driver/oracle/OracleQueryRunner.js.map +1 -1
  46. package/browser/driver/postgres/PostgresQueryRunner.js +52 -19
  47. package/browser/driver/postgres/PostgresQueryRunner.js.map +1 -1
  48. package/browser/driver/sap/SapQueryRunner.js +1 -1
  49. package/browser/driver/sap/SapQueryRunner.js.map +1 -1
  50. package/browser/driver/sqlite/SqliteDriver.js +11 -10
  51. package/browser/driver/sqlite/SqliteDriver.js.map +1 -1
  52. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +1 -1
  53. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  54. package/browser/entity-manager/EntityManager.d.ts +2 -2
  55. package/browser/entity-manager/EntityManager.js +2 -12
  56. package/browser/entity-manager/EntityManager.js.map +1 -1
  57. package/browser/entity-manager/MongoEntityManager.d.ts +2 -0
  58. package/browser/entity-manager/MongoEntityManager.js +37 -5
  59. package/browser/entity-manager/MongoEntityManager.js.map +1 -1
  60. package/browser/entity-schema/EntitySchemaOptions.d.ts +6 -0
  61. package/browser/entity-schema/EntitySchemaOptions.js.map +1 -1
  62. package/browser/entity-schema/EntitySchemaRelationOptions.d.ts +7 -1
  63. package/browser/entity-schema/EntitySchemaRelationOptions.js.map +1 -1
  64. package/browser/entity-schema/EntitySchemaTransformer.js +4 -1
  65. package/browser/entity-schema/EntitySchemaTransformer.js.map +1 -1
  66. package/browser/entity-schema/EntitySchemaUniqueOptions.d.ts +5 -0
  67. package/browser/entity-schema/EntitySchemaUniqueOptions.js.map +1 -1
  68. package/browser/find-options/FindOneOptions.d.ts +6 -0
  69. package/browser/find-options/FindOneOptions.js.map +1 -1
  70. package/browser/find-options/FindOptionsUtils.js +4 -0
  71. package/browser/find-options/FindOptionsUtils.js.map +1 -1
  72. package/browser/find-options/operator/Like.d.ts +1 -1
  73. package/browser/find-options/operator/Like.js +1 -1
  74. package/browser/find-options/operator/Like.js.map +1 -1
  75. package/browser/find-options/operator/Not.d.ts +1 -1
  76. package/browser/find-options/operator/Not.js +1 -1
  77. package/browser/find-options/operator/Not.js.map +1 -1
  78. package/browser/globals.js +34 -7
  79. package/browser/globals.js.map +1 -1
  80. package/browser/index.d.ts +2 -0
  81. package/browser/index.js +2 -0
  82. package/browser/index.js.map +1 -1
  83. package/browser/metadata/ColumnMetadata.d.ts +4 -0
  84. package/browser/metadata/ColumnMetadata.js +2 -0
  85. package/browser/metadata/ColumnMetadata.js.map +1 -1
  86. package/browser/metadata/RelationMetadata.d.ts +1 -1
  87. package/browser/metadata/RelationMetadata.js.map +1 -1
  88. package/browser/metadata/UniqueMetadata.d.ts +5 -0
  89. package/browser/metadata/UniqueMetadata.js +1 -0
  90. package/browser/metadata/UniqueMetadata.js.map +1 -1
  91. package/browser/metadata-args/UniqueMetadataArgs.d.ts +5 -0
  92. package/browser/metadata-args/UniqueMetadataArgs.js.map +1 -1
  93. package/browser/metadata-builder/EntityMetadataValidator.js +1 -0
  94. package/browser/metadata-builder/EntityMetadataValidator.js.map +1 -1
  95. package/browser/migration/MigrationExecutor.js +1 -1
  96. package/browser/migration/MigrationExecutor.js.map +1 -1
  97. package/browser/persistence/subject-builder/OneToManySubjectBuilder.js +3 -0
  98. package/browser/persistence/subject-builder/OneToManySubjectBuilder.js.map +1 -1
  99. package/browser/platform/PlatformTools.d.ts +1 -0
  100. package/browser/platform/PlatformTools.js +5 -0
  101. package/browser/platform/PlatformTools.js.map +1 -1
  102. package/browser/query-builder/DeleteQueryBuilder.d.ts +4 -2
  103. package/browser/query-builder/DeleteQueryBuilder.js +4 -2
  104. package/browser/query-builder/DeleteQueryBuilder.js.map +1 -1
  105. package/browser/query-builder/InsertQueryBuilder.d.ts +1 -1
  106. package/browser/query-builder/InsertQueryBuilder.js +3 -3
  107. package/browser/query-builder/InsertQueryBuilder.js.map +1 -1
  108. package/browser/query-builder/NotBrackets.d.ts +7 -0
  109. package/browser/query-builder/NotBrackets.js +16 -0
  110. package/browser/query-builder/NotBrackets.js.map +1 -0
  111. package/browser/query-builder/QueryBuilder.d.ts +3 -2
  112. package/browser/query-builder/QueryBuilder.js +2 -1
  113. package/browser/query-builder/QueryBuilder.js.map +1 -1
  114. package/browser/query-builder/RelationLoader.js +11 -6
  115. package/browser/query-builder/RelationLoader.js.map +1 -1
  116. package/browser/query-builder/RelationQueryBuilder.d.ts +1 -1
  117. package/browser/query-builder/RelationQueryBuilder.js +1 -1
  118. package/browser/query-builder/RelationQueryBuilder.js.map +1 -1
  119. package/browser/query-builder/SelectQueryBuilder.d.ts +10 -1
  120. package/browser/query-builder/SelectQueryBuilder.js +28 -21
  121. package/browser/query-builder/SelectQueryBuilder.js.map +1 -1
  122. package/browser/query-builder/SoftDeleteQueryBuilder.d.ts +1 -1
  123. package/browser/query-builder/SoftDeleteQueryBuilder.js +1 -1
  124. package/browser/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  125. package/browser/query-builder/UpdateQueryBuilder.d.ts +4 -2
  126. package/browser/query-builder/UpdateQueryBuilder.js +11 -6
  127. package/browser/query-builder/UpdateQueryBuilder.js.map +1 -1
  128. package/browser/query-builder/WhereExpressionBuilder.d.ts +3 -1
  129. package/browser/query-builder/WhereExpressionBuilder.js.map +1 -1
  130. package/browser/query-runner/BaseQueryRunner.d.ts +2 -2
  131. package/browser/query-runner/BaseQueryRunner.js +3 -3
  132. package/browser/query-runner/BaseQueryRunner.js.map +1 -1
  133. package/browser/repository/AbstractRepository.d.ts +2 -2
  134. package/browser/repository/AbstractRepository.js +2 -2
  135. package/browser/repository/AbstractRepository.js.map +1 -1
  136. package/browser/repository/BaseEntity.d.ts +1 -1
  137. package/browser/repository/BaseEntity.js +1 -1
  138. package/browser/repository/BaseEntity.js.map +1 -1
  139. package/browser/repository/Repository.d.ts +1 -1
  140. package/browser/repository/Repository.js +1 -1
  141. package/browser/repository/Repository.js.map +1 -1
  142. package/browser/repository/TreeRepository.js +1 -1
  143. package/browser/repository/TreeRepository.js.map +1 -1
  144. package/browser/schema-builder/RdbmsSchemaBuilder.js +1 -1
  145. package/browser/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  146. package/browser/schema-builder/options/TableColumnOptions.d.ts +4 -0
  147. package/browser/schema-builder/options/TableColumnOptions.js.map +1 -1
  148. package/browser/schema-builder/options/TableUniqueOptions.d.ts +5 -0
  149. package/browser/schema-builder/options/TableUniqueOptions.js.map +1 -1
  150. package/browser/schema-builder/table/TableColumn.d.ts +4 -0
  151. package/browser/schema-builder/table/TableColumn.js +2 -0
  152. package/browser/schema-builder/table/TableColumn.js.map +1 -1
  153. package/browser/schema-builder/table/TableUnique.d.ts +5 -0
  154. package/browser/schema-builder/table/TableUnique.js +5 -2
  155. package/browser/schema-builder/table/TableUnique.js.map +1 -1
  156. package/browser/schema-builder/util/TableUtils.js +1 -0
  157. package/browser/schema-builder/util/TableUtils.js.map +1 -1
  158. package/browser/util/DirectoryExportedClassesLoader.d.ts +1 -1
  159. package/browser/util/DirectoryExportedClassesLoader.js +55 -31
  160. package/browser/util/DirectoryExportedClassesLoader.js.map +1 -1
  161. package/browser/util/ImportUtils.d.ts +1 -0
  162. package/browser/util/ImportUtils.js +90 -0
  163. package/browser/util/ImportUtils.js.map +1 -0
  164. package/browser/util/RandomGenerator.d.ts +0 -4
  165. package/browser/util/RandomGenerator.js +0 -9
  166. package/browser/util/RandomGenerator.js.map +1 -1
  167. package/cache/RedisQueryResultCache.js +39 -34
  168. package/cache/RedisQueryResultCache.js.map +1 -1
  169. package/commands/CacheClearCommand.js +3 -3
  170. package/commands/CacheClearCommand.js.map +1 -1
  171. package/commands/CommandUtils.d.ts +4 -0
  172. package/commands/CommandUtils.js +10 -0
  173. package/commands/CommandUtils.js.map +1 -1
  174. package/commands/EntityCreateCommand.js +2 -2
  175. package/commands/EntityCreateCommand.js.map +1 -1
  176. package/commands/InitCommand.d.ts +9 -7
  177. package/commands/InitCommand.js +74 -45
  178. package/commands/InitCommand.js.map +1 -1
  179. package/commands/MigrationCreateCommand.d.ts +2 -0
  180. package/commands/MigrationCreateCommand.js +9 -3
  181. package/commands/MigrationCreateCommand.js.map +1 -1
  182. package/commands/MigrationGenerateCommand.d.ts +2 -0
  183. package/commands/MigrationGenerateCommand.js +9 -3
  184. package/commands/MigrationGenerateCommand.js.map +1 -1
  185. package/commands/MigrationRevertCommand.js +2 -3
  186. package/commands/MigrationRevertCommand.js.map +1 -1
  187. package/commands/MigrationRunCommand.js +2 -3
  188. package/commands/MigrationRunCommand.js.map +1 -1
  189. package/commands/MigrationShowCommand.js +2 -3
  190. package/commands/MigrationShowCommand.js.map +1 -1
  191. package/commands/QueryCommand.d.ts +1 -1
  192. package/commands/QueryCommand.js +2 -3
  193. package/commands/QueryCommand.js.map +1 -1
  194. package/commands/SchemaDropCommand.js +2 -2
  195. package/commands/SchemaDropCommand.js.map +1 -1
  196. package/commands/SchemaLogCommand.js +2 -2
  197. package/commands/SchemaLogCommand.js.map +1 -1
  198. package/commands/SchemaSyncCommand.js +2 -2
  199. package/commands/SchemaSyncCommand.js.map +1 -1
  200. package/commands/SubscriberCreateCommand.js +3 -3
  201. package/commands/SubscriberCreateCommand.js.map +1 -1
  202. package/common/RelationType.d.ts +14 -0
  203. package/common/RelationType.js +4 -0
  204. package/common/RelationType.js.map +1 -0
  205. package/connection/BaseConnectionOptions.d.ts +5 -0
  206. package/connection/BaseConnectionOptions.js.map +1 -1
  207. package/connection/Connection.d.ts +7 -3
  208. package/connection/Connection.js +47 -31
  209. package/connection/Connection.js.map +1 -1
  210. package/connection/ConnectionMetadataBuilder.d.ts +3 -3
  211. package/connection/ConnectionMetadataBuilder.js +53 -21
  212. package/connection/ConnectionMetadataBuilder.js.map +1 -1
  213. package/connection/ConnectionOptionsReader.js +32 -27
  214. package/connection/ConnectionOptionsReader.js.map +1 -1
  215. package/connection/options-reader/ConnectionOptionsEnvReader.js +1 -0
  216. package/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
  217. package/decorator/Unique.d.ts +5 -4
  218. package/decorator/Unique.js +7 -3
  219. package/decorator/Unique.js.map +1 -1
  220. package/decorator/columns/PrimaryGeneratedColumn.d.ts +2 -1
  221. package/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
  222. package/decorator/options/ColumnOptions.d.ts +4 -0
  223. package/decorator/options/ColumnOptions.js.map +1 -1
  224. package/decorator/options/PrimaryGeneratedColumnIdentityOptions.d.ts +22 -0
  225. package/decorator/options/PrimaryGeneratedColumnIdentityOptions.js +4 -0
  226. package/decorator/options/PrimaryGeneratedColumnIdentityOptions.js.map +1 -0
  227. package/decorator/options/RelationOptions.d.ts +1 -1
  228. package/decorator/options/RelationOptions.js.map +1 -1
  229. package/decorator/options/UniqueOptions.d.ts +10 -0
  230. package/decorator/options/UniqueOptions.js +4 -0
  231. package/decorator/options/UniqueOptions.js.map +1 -0
  232. package/driver/aurora-data-api/AuroraDataApiQueryRunner.js +2 -2
  233. package/driver/aurora-data-api/AuroraDataApiQueryRunner.js.map +1 -1
  234. package/driver/better-sqlite3/BetterSqlite3Driver.js +7 -5
  235. package/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -1
  236. package/driver/cockroachdb/CockroachQueryRunner.js +1 -1
  237. package/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  238. package/driver/mongodb/MongoConnectionOptions.d.ts +1 -1
  239. package/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  240. package/driver/mysql/MysqlQueryRunner.js +1 -1
  241. package/driver/mysql/MysqlQueryRunner.js.map +1 -1
  242. package/driver/oracle/OracleQueryRunner.js +1 -1
  243. package/driver/oracle/OracleQueryRunner.js.map +1 -1
  244. package/driver/postgres/PostgresQueryRunner.js +52 -19
  245. package/driver/postgres/PostgresQueryRunner.js.map +1 -1
  246. package/driver/sap/SapQueryRunner.js +1 -1
  247. package/driver/sap/SapQueryRunner.js.map +1 -1
  248. package/driver/sqlite/SqliteDriver.js +11 -10
  249. package/driver/sqlite/SqliteDriver.js.map +1 -1
  250. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +1 -1
  251. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  252. package/entity-manager/EntityManager.d.ts +2 -2
  253. package/entity-manager/EntityManager.js +2 -12
  254. package/entity-manager/EntityManager.js.map +1 -1
  255. package/entity-manager/MongoEntityManager.d.ts +2 -0
  256. package/entity-manager/MongoEntityManager.js +37 -5
  257. package/entity-manager/MongoEntityManager.js.map +1 -1
  258. package/entity-schema/EntitySchemaOptions.d.ts +6 -0
  259. package/entity-schema/EntitySchemaOptions.js.map +1 -1
  260. package/entity-schema/EntitySchemaRelationOptions.d.ts +7 -1
  261. package/entity-schema/EntitySchemaRelationOptions.js.map +1 -1
  262. package/entity-schema/EntitySchemaTransformer.js +4 -1
  263. package/entity-schema/EntitySchemaTransformer.js.map +1 -1
  264. package/entity-schema/EntitySchemaUniqueOptions.d.ts +5 -0
  265. package/entity-schema/EntitySchemaUniqueOptions.js.map +1 -1
  266. package/find-options/FindOneOptions.d.ts +6 -0
  267. package/find-options/FindOneOptions.js.map +1 -1
  268. package/find-options/FindOptionsUtils.js +4 -0
  269. package/find-options/FindOptionsUtils.js.map +1 -1
  270. package/find-options/operator/Like.d.ts +1 -1
  271. package/find-options/operator/Like.js +1 -1
  272. package/find-options/operator/Like.js.map +1 -1
  273. package/find-options/operator/Not.d.ts +1 -1
  274. package/find-options/operator/Not.js +1 -1
  275. package/find-options/operator/Not.js.map +1 -1
  276. package/globals.js +33 -6
  277. package/globals.js.map +1 -1
  278. package/index.d.ts +2 -0
  279. package/index.js +4 -1
  280. package/index.js.map +1 -1
  281. package/index.mjs +352 -0
  282. package/metadata/ColumnMetadata.d.ts +4 -0
  283. package/metadata/ColumnMetadata.js +2 -0
  284. package/metadata/ColumnMetadata.js.map +1 -1
  285. package/metadata/RelationMetadata.d.ts +1 -1
  286. package/metadata/RelationMetadata.js.map +1 -1
  287. package/metadata/UniqueMetadata.d.ts +5 -0
  288. package/metadata/UniqueMetadata.js +1 -0
  289. package/metadata/UniqueMetadata.js.map +1 -1
  290. package/metadata-args/UniqueMetadataArgs.d.ts +5 -0
  291. package/metadata-args/UniqueMetadataArgs.js.map +1 -1
  292. package/metadata-builder/EntityMetadataValidator.js +1 -0
  293. package/metadata-builder/EntityMetadataValidator.js.map +1 -1
  294. package/migration/MigrationExecutor.js +1 -1
  295. package/migration/MigrationExecutor.js.map +1 -1
  296. package/package.json +1 -1
  297. package/persistence/subject-builder/OneToManySubjectBuilder.js +3 -0
  298. package/persistence/subject-builder/OneToManySubjectBuilder.js.map +1 -1
  299. package/platform/PlatformTools.d.ts +1 -0
  300. package/platform/PlatformTools.js +5 -0
  301. package/platform/PlatformTools.js.map +1 -1
  302. package/query-builder/DeleteQueryBuilder.d.ts +4 -2
  303. package/query-builder/DeleteQueryBuilder.js +4 -2
  304. package/query-builder/DeleteQueryBuilder.js.map +1 -1
  305. package/query-builder/InsertQueryBuilder.d.ts +1 -1
  306. package/query-builder/InsertQueryBuilder.js +3 -3
  307. package/query-builder/InsertQueryBuilder.js.map +1 -1
  308. package/query-builder/NotBrackets.d.ts +7 -0
  309. package/query-builder/NotBrackets.js +19 -0
  310. package/query-builder/NotBrackets.js.map +1 -0
  311. package/query-builder/QueryBuilder.d.ts +3 -2
  312. package/query-builder/QueryBuilder.js +2 -1
  313. package/query-builder/QueryBuilder.js.map +1 -1
  314. package/query-builder/RelationLoader.js +11 -6
  315. package/query-builder/RelationLoader.js.map +1 -1
  316. package/query-builder/RelationQueryBuilder.d.ts +1 -1
  317. package/query-builder/RelationQueryBuilder.js +1 -1
  318. package/query-builder/RelationQueryBuilder.js.map +1 -1
  319. package/query-builder/SelectQueryBuilder.d.ts +10 -1
  320. package/query-builder/SelectQueryBuilder.js +28 -21
  321. package/query-builder/SelectQueryBuilder.js.map +1 -1
  322. package/query-builder/SoftDeleteQueryBuilder.d.ts +1 -1
  323. package/query-builder/SoftDeleteQueryBuilder.js +1 -1
  324. package/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  325. package/query-builder/UpdateQueryBuilder.d.ts +4 -2
  326. package/query-builder/UpdateQueryBuilder.js +11 -6
  327. package/query-builder/UpdateQueryBuilder.js.map +1 -1
  328. package/query-builder/WhereExpressionBuilder.d.ts +3 -1
  329. package/query-builder/WhereExpressionBuilder.js.map +1 -1
  330. package/query-runner/BaseQueryRunner.d.ts +2 -2
  331. package/query-runner/BaseQueryRunner.js +3 -3
  332. package/query-runner/BaseQueryRunner.js.map +1 -1
  333. package/repository/AbstractRepository.d.ts +2 -2
  334. package/repository/AbstractRepository.js +2 -2
  335. package/repository/AbstractRepository.js.map +1 -1
  336. package/repository/BaseEntity.d.ts +1 -1
  337. package/repository/BaseEntity.js +1 -1
  338. package/repository/BaseEntity.js.map +1 -1
  339. package/repository/Repository.d.ts +1 -1
  340. package/repository/Repository.js +1 -1
  341. package/repository/Repository.js.map +1 -1
  342. package/repository/TreeRepository.js +1 -1
  343. package/repository/TreeRepository.js.map +1 -1
  344. package/schema-builder/RdbmsSchemaBuilder.js +1 -1
  345. package/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  346. package/schema-builder/options/TableColumnOptions.d.ts +4 -0
  347. package/schema-builder/options/TableColumnOptions.js.map +1 -1
  348. package/schema-builder/options/TableUniqueOptions.d.ts +5 -0
  349. package/schema-builder/options/TableUniqueOptions.js.map +1 -1
  350. package/schema-builder/table/TableColumn.d.ts +4 -0
  351. package/schema-builder/table/TableColumn.js +2 -0
  352. package/schema-builder/table/TableColumn.js.map +1 -1
  353. package/schema-builder/table/TableUnique.d.ts +5 -0
  354. package/schema-builder/table/TableUnique.js +5 -2
  355. package/schema-builder/table/TableUnique.js.map +1 -1
  356. package/schema-builder/util/TableUtils.js +1 -0
  357. package/schema-builder/util/TableUtils.js.map +1 -1
  358. package/util/DirectoryExportedClassesLoader.d.ts +1 -1
  359. package/util/DirectoryExportedClassesLoader.js +54 -31
  360. package/util/DirectoryExportedClassesLoader.js.map +1 -1
  361. package/util/ImportUtils.d.ts +1 -0
  362. package/util/ImportUtils.js +94 -0
  363. package/util/ImportUtils.js.map +1 -0
  364. package/util/RandomGenerator.d.ts +0 -4
  365. package/util/RandomGenerator.js +0 -9
  366. package/util/RandomGenerator.js.map +1 -1
@@ -5,6 +5,7 @@ var tslib_1 = require("tslib");
5
5
  var globals_1 = require("../globals");
6
6
  var ConnectionOptionsReader_1 = require("../connection/ConnectionOptionsReader");
7
7
  var chalk_1 = (0, tslib_1.__importDefault)(require("chalk"));
8
+ var PlatformTools_1 = require("../platform/PlatformTools");
8
9
  /**
9
10
  * Clear cache command.
10
11
  */
@@ -54,7 +55,7 @@ var CacheClearCommand = /** @class */ (function () {
54
55
  case 3:
55
56
  connection = _a.sent();
56
57
  if (!connection.queryResultCache) {
57
- console.log(chalk_1.default.black.bgRed("Cache is not enabled. To use cache enable it in connection configuration."));
58
+ PlatformTools_1.PlatformTools.logCmdErr("Cache is not enabled. To use cache enable it in connection configuration.");
58
59
  return [2 /*return*/];
59
60
  }
60
61
  return [4 /*yield*/, connection.queryResultCache.clear()];
@@ -75,8 +76,7 @@ var CacheClearCommand = /** @class */ (function () {
75
76
  _a.sent();
76
77
  _a.label = 9;
77
78
  case 9:
78
- console.log(chalk_1.default.black.bgRed("Error during cache clear:"));
79
- console.error(err_1);
79
+ PlatformTools_1.PlatformTools.logCmdErr("Error during cache clear.", err_1);
80
80
  process.exit(1);
81
81
  return [3 /*break*/, 10];
82
82
  case 10: return [2 /*return*/];
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/commands/CacheClearCommand.ts"],"names":[],"mappings":";;;;AAAA,sCAA4C;AAC5C,iFAA8E;AAG9E,6DAA0B;AAE1B;;GAEG;AACH;IAAA;QAEI,YAAO,GAAG,aAAa,CAAC;QACxB,aAAQ,GAAG,+CAA+C,CAAC;IAqD/D,CAAC;IAnDG,mCAAO,GAAP,UAAQ,IAAgB;QACpB,OAAO,IAAI;aACN,MAAM,CAAC,YAAY,EAAE;YAClB,KAAK,EAAE,GAAG;YACV,OAAO,EAAE,SAAS;YAClB,QAAQ,EAAE,8CAA8C;SAC3D,CAAC;aACD,MAAM,CAAC,QAAQ,EAAE;YACd,KAAK,EAAE,GAAG;YACV,OAAO,EAAE,WAAW;YACpB,QAAQ,EAAE,iDAAiD;SAC9D,CAAC,CAAC;IACX,CAAC;IAEK,mCAAO,GAAb,UAAc,IAAqB;;;;;;wBAE3B,UAAU,GAAyB,SAAS,CAAC;;;;wBAEvC,uBAAuB,GAAG,IAAI,iDAAuB,CAAC;4BACxD,IAAI,EAAE,OAAO,CAAC,GAAG,EAAE;4BACnB,UAAU,EAAE,IAAI,CAAC,MAAa;yBACjC,CAAC,CAAC;wBACuB,qBAAM,uBAAuB,CAAC,GAAG,CAAC,IAAI,CAAC,UAAiB,CAAC,EAAA;;wBAA7E,iBAAiB,GAAG,SAAyD;wBACnF,MAAM,CAAC,MAAM,CAAC,iBAAiB,EAAE;4BAC7B,WAAW,EAAE,EAAE;4BACf,WAAW,EAAE,KAAK;4BAClB,aAAa,EAAE,KAAK;4BACpB,UAAU,EAAE,KAAK;4BACjB,OAAO,EAAE,CAAC,QAAQ,CAAC;yBACtB,CAAC,CAAC;wBACU,qBAAM,IAAA,0BAAgB,EAAC,iBAAiB,CAAC,EAAA;;wBAAtD,UAAU,GAAG,SAAyC,CAAC;wBAEvD,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE;4BAC9B,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,KAAK,CAAC,2EAA2E,CAAC,CAAC,CAAC;4BAC5G,sBAAO;yBACV;wBAED,qBAAM,UAAU,CAAC,gBAAgB,CAAC,KAAK,EAAE,EAAA;;wBAAzC,SAAyC,CAAC;wBAC1C,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAC,CAAC;6BAEvD,UAAU,EAAV,wBAAU;wBAAE,qBAAM,UAAU,CAAC,KAAK,EAAE,EAAA;;wBAAxB,SAAwB,CAAC;;;;;6BAGrC,UAAU,EAAV,wBAAU;wBAAE,qBAAO,UAAyB,CAAC,KAAK,EAAE,EAAA;;wBAAxC,SAAwC,CAAC;;;wBAEzD,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,KAAK,CAAC,2BAA2B,CAAC,CAAC,CAAC;wBAC5D,OAAO,CAAC,KAAK,CAAC,KAAG,CAAC,CAAC;wBACnB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;;;;;;KAEvB;IAEL,wBAAC;AAAD,CAxDA,AAwDC,IAAA;AAxDY,8CAAiB","file":"CacheClearCommand.js","sourcesContent":["import {createConnection} from \"../globals\";\nimport {ConnectionOptionsReader} from \"../connection/ConnectionOptionsReader\";\nimport {Connection} from \"../connection/Connection\";\nimport * as yargs from \"yargs\";\nimport chalk from \"chalk\";\n\n/**\n * Clear cache command.\n */\nexport class CacheClearCommand implements yargs.CommandModule {\n\n command = \"cache:clear\";\n describe = \"Clears all data stored in query runner cache.\";\n\n builder(args: yargs.Argv) {\n return args\n .option(\"connection\", {\n alias: \"c\",\n default: \"default\",\n describe: \"Name of the connection on which run a query.\"\n })\n .option(\"config\", {\n alias: \"f\",\n default: \"ormconfig\",\n describe: \"Name of the file with connection configuration.\"\n });\n }\n\n async handler(args: yargs.Arguments) {\n\n let connection: Connection|undefined = undefined;\n try {\n const connectionOptionsReader = new ConnectionOptionsReader({\n root: process.cwd(),\n configName: args.config as any\n });\n const connectionOptions = await connectionOptionsReader.get(args.connection as any);\n Object.assign(connectionOptions, {\n subscribers: [],\n synchronize: false,\n migrationsRun: false,\n dropSchema: false,\n logging: [\"schema\"]\n });\n connection = await createConnection(connectionOptions);\n\n if (!connection.queryResultCache) {\n console.log(chalk.black.bgRed(\"Cache is not enabled. To use cache enable it in connection configuration.\"));\n return;\n }\n\n await connection.queryResultCache.clear();\n console.log(chalk.green(\"Cache was successfully cleared\"));\n\n if (connection) await connection.close();\n\n } catch (err) {\n if (connection) await (connection as Connection).close();\n\n console.log(chalk.black.bgRed(\"Error during cache clear:\"));\n console.error(err);\n process.exit(1);\n }\n }\n\n}\n"],"sourceRoot":".."}
1
+ {"version":3,"sources":["../../src/commands/CacheClearCommand.ts"],"names":[],"mappings":";;;;AAAA,sCAA4C;AAC5C,iFAA8E;AAG9E,6DAA0B;AAC1B,2DAA0D;AAE1D;;GAEG;AACH;IAAA;QAEI,YAAO,GAAG,aAAa,CAAC;QACxB,aAAQ,GAAG,+CAA+C,CAAC;IAqD/D,CAAC;IAnDG,mCAAO,GAAP,UAAQ,IAAgB;QACpB,OAAO,IAAI;aACN,MAAM,CAAC,YAAY,EAAE;YAClB,KAAK,EAAE,GAAG;YACV,OAAO,EAAE,SAAS;YAClB,QAAQ,EAAE,8CAA8C;SAC3D,CAAC;aACD,MAAM,CAAC,QAAQ,EAAE;YACd,KAAK,EAAE,GAAG;YACV,OAAO,EAAE,WAAW;YACpB,QAAQ,EAAE,iDAAiD;SAC9D,CAAC,CAAC;IACX,CAAC;IAEK,mCAAO,GAAb,UAAc,IAAqB;;;;;;wBAE3B,UAAU,GAAyB,SAAS,CAAC;;;;wBAEvC,uBAAuB,GAAG,IAAI,iDAAuB,CAAC;4BACxD,IAAI,EAAE,OAAO,CAAC,GAAG,EAAE;4BACnB,UAAU,EAAE,IAAI,CAAC,MAAa;yBACjC,CAAC,CAAC;wBACuB,qBAAM,uBAAuB,CAAC,GAAG,CAAC,IAAI,CAAC,UAAiB,CAAC,EAAA;;wBAA7E,iBAAiB,GAAG,SAAyD;wBACnF,MAAM,CAAC,MAAM,CAAC,iBAAiB,EAAE;4BAC7B,WAAW,EAAE,EAAE;4BACf,WAAW,EAAE,KAAK;4BAClB,aAAa,EAAE,KAAK;4BACpB,UAAU,EAAE,KAAK;4BACjB,OAAO,EAAE,CAAC,QAAQ,CAAC;yBACtB,CAAC,CAAC;wBACU,qBAAM,IAAA,0BAAgB,EAAC,iBAAiB,CAAC,EAAA;;wBAAtD,UAAU,GAAG,SAAyC,CAAC;wBAEvD,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE;4BAC9B,6BAAa,CAAC,SAAS,CAAC,2EAA2E,CAAC,CAAC;4BACrG,sBAAO;yBACV;wBAED,qBAAM,UAAU,CAAC,gBAAgB,CAAC,KAAK,EAAE,EAAA;;wBAAzC,SAAyC,CAAC;wBAC1C,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAC,CAAC;6BAEvD,UAAU,EAAV,wBAAU;wBAAE,qBAAM,UAAU,CAAC,KAAK,EAAE,EAAA;;wBAAxB,SAAwB,CAAC;;;;;6BAGrC,UAAU,EAAV,wBAAU;wBAAE,qBAAO,UAAyB,CAAC,KAAK,EAAE,EAAA;;wBAAxC,SAAwC,CAAC;;;wBAEzD,6BAAa,CAAC,SAAS,CAAC,2BAA2B,EAAE,KAAG,CAAC,CAAC;wBAE1D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;;;;;;KAEvB;IAEL,wBAAC;AAAD,CAxDA,AAwDC,IAAA;AAxDY,8CAAiB","file":"CacheClearCommand.js","sourcesContent":["import {createConnection} from \"../globals\";\nimport {ConnectionOptionsReader} from \"../connection/ConnectionOptionsReader\";\nimport {Connection} from \"../connection/Connection\";\nimport * as yargs from \"yargs\";\nimport chalk from \"chalk\";\nimport { PlatformTools } from \"../platform/PlatformTools\";\n\n/**\n * Clear cache command.\n */\nexport class CacheClearCommand implements yargs.CommandModule {\n\n command = \"cache:clear\";\n describe = \"Clears all data stored in query runner cache.\";\n\n builder(args: yargs.Argv) {\n return args\n .option(\"connection\", {\n alias: \"c\",\n default: \"default\",\n describe: \"Name of the connection on which run a query.\"\n })\n .option(\"config\", {\n alias: \"f\",\n default: \"ormconfig\",\n describe: \"Name of the file with connection configuration.\"\n });\n }\n\n async handler(args: yargs.Arguments) {\n\n let connection: Connection|undefined = undefined;\n try {\n const connectionOptionsReader = new ConnectionOptionsReader({\n root: process.cwd(),\n configName: args.config as any\n });\n const connectionOptions = await connectionOptionsReader.get(args.connection as any);\n Object.assign(connectionOptions, {\n subscribers: [],\n synchronize: false,\n migrationsRun: false,\n dropSchema: false,\n logging: [\"schema\"]\n });\n connection = await createConnection(connectionOptions);\n\n if (!connection.queryResultCache) {\n PlatformTools.logCmdErr(\"Cache is not enabled. To use cache enable it in connection configuration.\");\n return;\n }\n\n await connection.queryResultCache.clear();\n console.log(chalk.green(\"Cache was successfully cleared\"));\n\n if (connection) await connection.close();\n\n } catch (err) {\n if (connection) await (connection as Connection).close();\n\n PlatformTools.logCmdErr(\"Error during cache clear.\", err);\n\n process.exit(1);\n }\n }\n\n}\n"],"sourceRoot":".."}
@@ -15,4 +15,8 @@ export declare class CommandUtils {
15
15
  */
16
16
  static readFile(filePath: string): Promise<string>;
17
17
  static fileExists(filePath: string): Promise<boolean>;
18
+ /**
19
+ * Gets migration timestamp and validates argument (if sent)
20
+ */
21
+ static getTimestamp(timestampOptionArgument: any): number;
18
22
  }
@@ -5,6 +5,7 @@ var tslib_1 = require("tslib");
5
5
  var fs = (0, tslib_1.__importStar)(require("fs"));
6
6
  var path = (0, tslib_1.__importStar)(require("path"));
7
7
  var mkdirp_1 = (0, tslib_1.__importDefault)(require("mkdirp"));
8
+ var error_1 = require("../error");
8
9
  /**
9
10
  * Command line utils functions.
10
11
  */
@@ -56,6 +57,15 @@ var CommandUtils = /** @class */ (function () {
56
57
  });
57
58
  });
58
59
  };
60
+ /**
61
+ * Gets migration timestamp and validates argument (if sent)
62
+ */
63
+ CommandUtils.getTimestamp = function (timestampOptionArgument) {
64
+ if (timestampOptionArgument && (isNaN(timestampOptionArgument) || timestampOptionArgument < 0)) {
65
+ throw new error_1.TypeORMError("timestamp option should be a non-negative number. received: " + timestampOptionArgument);
66
+ }
67
+ return timestampOptionArgument ? new Date(Number(timestampOptionArgument)).getTime() : Date.now();
68
+ };
59
69
  return CommandUtils;
60
70
  }());
61
71
  exports.CommandUtils = CommandUtils;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/commands/CommandUtils.ts"],"names":[],"mappings":";;;;AAAA,kDAAyB;AACzB,sDAA6B;AAC7B,+DAA4B;AAE5B;;GAEG;AACH;IAAA;IAmCA,CAAC;IAjCG;;OAEG;IACI,8BAAiB,GAAxB,UAAyB,SAAiB;QACtC,OAAO,IAAA,gBAAM,EAAC,SAAS,CAAC,CAAC;IAC7B,CAAC;IAED;;OAEG;IACU,uBAAU,GAAvB,UAAwB,QAAgB,EAAE,OAAe,EAAE,QAAwB;QAAxB,yBAAA,EAAA,eAAwB;;;;4BAC/E,qBAAM,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,EAAA;;wBAA5D,SAA4D,CAAC;wBAC7D,sBAAO,IAAI,OAAO,CAAO,UAAC,EAAE,EAAE,IAAI;gCAC9B,IAAI,QAAQ,KAAK,KAAK,IAAI,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC;oCAC7C,OAAO,EAAE,EAAE,CAAC;gCAEhB,EAAE,CAAC,SAAS,CAAC,QAAQ,EAAE,OAAO,EAAE,UAAA,GAAG,IAAI,OAAA,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,EAAtB,CAAsB,CAAC,CAAC;4BACnE,CAAC,CAAC,EAAC;;;;KACN;IAED;;OAEG;IACU,qBAAQ,GAArB,UAAsB,QAAgB;;;gBAClC,sBAAO,IAAI,OAAO,CAAS,UAAC,EAAE,EAAE,IAAI;wBAChC,EAAE,CAAC,QAAQ,CAAC,QAAQ,EAAE,UAAC,GAAG,EAAE,IAAI,IAAK,OAAA,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,EAArC,CAAqC,CAAC,CAAC;oBAChF,CAAC,CAAC,EAAC;;;KACN;IAGY,uBAAU,GAAvB,UAAwB,QAAgB;;;gBACpC,sBAAO,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAC;;;KAClC;IACL,mBAAC;AAAD,CAnCA,AAmCC,IAAA;AAnCY,oCAAY","file":"CommandUtils.js","sourcesContent":["import * as fs from \"fs\";\nimport * as path from \"path\";\nimport mkdirp from \"mkdirp\";\n\n/**\n * Command line utils functions.\n */\nexport class CommandUtils {\n\n /**\n * Creates directories recursively.\n */\n static createDirectories(directory: string) {\n return mkdirp(directory);\n }\n\n /**\n * Creates a file with the given content in the given path.\n */\n static async createFile(filePath: string, content: string, override: boolean = true): Promise<void> {\n await CommandUtils.createDirectories(path.dirname(filePath));\n return new Promise<void>((ok, fail) => {\n if (override === false && fs.existsSync(filePath))\n return ok();\n\n fs.writeFile(filePath, content, err => err ? fail(err) : ok());\n });\n }\n\n /**\n * Reads everything from a given file and returns its content as a string.\n */\n static async readFile(filePath: string): Promise<string> {\n return new Promise<string>((ok, fail) => {\n fs.readFile(filePath, (err, data) => err ? fail(err) : ok(data.toString()));\n });\n }\n\n\n static async fileExists(filePath: string) {\n return fs.existsSync(filePath);\n }\n}\n"],"sourceRoot":".."}
1
+ {"version":3,"sources":["../../src/commands/CommandUtils.ts"],"names":[],"mappings":";;;;AAAA,kDAAyB;AACzB,sDAA6B;AAC7B,+DAA4B;AAC5B,kCAAsC;AAEtC;;GAEG;AACH;IAAA;IA6CA,CAAC;IA3CG;;OAEG;IACI,8BAAiB,GAAxB,UAAyB,SAAiB;QACtC,OAAO,IAAA,gBAAM,EAAC,SAAS,CAAC,CAAC;IAC7B,CAAC;IAED;;OAEG;IACU,uBAAU,GAAvB,UAAwB,QAAgB,EAAE,OAAe,EAAE,QAAwB;QAAxB,yBAAA,EAAA,eAAwB;;;;4BAC/E,qBAAM,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,EAAA;;wBAA5D,SAA4D,CAAC;wBAC7D,sBAAO,IAAI,OAAO,CAAO,UAAC,EAAE,EAAE,IAAI;gCAC9B,IAAI,QAAQ,KAAK,KAAK,IAAI,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC;oCAC7C,OAAO,EAAE,EAAE,CAAC;gCAEhB,EAAE,CAAC,SAAS,CAAC,QAAQ,EAAE,OAAO,EAAE,UAAA,GAAG,IAAI,OAAA,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,EAAtB,CAAsB,CAAC,CAAC;4BACnE,CAAC,CAAC,EAAC;;;;KACN;IAED;;OAEG;IACU,qBAAQ,GAArB,UAAsB,QAAgB;;;gBAClC,sBAAO,IAAI,OAAO,CAAS,UAAC,EAAE,EAAE,IAAI;wBAChC,EAAE,CAAC,QAAQ,CAAC,QAAQ,EAAE,UAAC,GAAG,EAAE,IAAI,IAAK,OAAA,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,EAArC,CAAqC,CAAC,CAAC;oBAChF,CAAC,CAAC,EAAC;;;KACN;IAGY,uBAAU,GAAvB,UAAwB,QAAgB;;;gBACpC,sBAAO,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAC;;;KAClC;IAED;;OAEG;IACI,yBAAY,GAAnB,UAAoB,uBAA4B;QAC5C,IAAI,uBAAuB,IAAI,CAAC,KAAK,CAAC,uBAAuB,CAAC,IAAI,uBAAuB,GAAG,CAAC,CAAC,EAAE;YAC5F,MAAM,IAAI,oBAAY,CAAC,iEAA+D,uBAAyB,CAAC,CAAC;SACpH;QACD,OAAO,uBAAuB,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,uBAAuB,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;IACtG,CAAC;IACL,mBAAC;AAAD,CA7CA,AA6CC,IAAA;AA7CY,oCAAY","file":"CommandUtils.js","sourcesContent":["import * as fs from \"fs\";\nimport * as path from \"path\";\nimport mkdirp from \"mkdirp\";\nimport {TypeORMError} from \"../error\";\n\n/**\n * Command line utils functions.\n */\nexport class CommandUtils {\n\n /**\n * Creates directories recursively.\n */\n static createDirectories(directory: string) {\n return mkdirp(directory);\n }\n\n /**\n * Creates a file with the given content in the given path.\n */\n static async createFile(filePath: string, content: string, override: boolean = true): Promise<void> {\n await CommandUtils.createDirectories(path.dirname(filePath));\n return new Promise<void>((ok, fail) => {\n if (override === false && fs.existsSync(filePath))\n return ok();\n\n fs.writeFile(filePath, content, err => err ? fail(err) : ok());\n });\n }\n\n /**\n * Reads everything from a given file and returns its content as a string.\n */\n static async readFile(filePath: string): Promise<string> {\n return new Promise<string>((ok, fail) => {\n fs.readFile(filePath, (err, data) => err ? fail(err) : ok(data.toString()));\n });\n }\n\n\n static async fileExists(filePath: string) {\n return fs.existsSync(filePath);\n }\n\n /**\n * Gets migration timestamp and validates argument (if sent)\n */\n static getTimestamp(timestampOptionArgument: any): number {\n if (timestampOptionArgument && (isNaN(timestampOptionArgument) || timestampOptionArgument < 0)) {\n throw new TypeORMError(`timestamp option should be a non-negative number. received: ${timestampOptionArgument}`);\n }\n return timestampOptionArgument ? new Date(Number(timestampOptionArgument)).getTime() : Date.now();\n }\n}\n"],"sourceRoot":".."}
@@ -5,6 +5,7 @@ var tslib_1 = require("tslib");
5
5
  var ConnectionOptionsReader_1 = require("../connection/ConnectionOptionsReader");
6
6
  var CommandUtils_1 = require("./CommandUtils");
7
7
  var chalk_1 = (0, tslib_1.__importDefault)(require("chalk"));
8
+ var PlatformTools_1 = require("../platform/PlatformTools");
8
9
  /**
9
10
  * Generates a new entity.
10
11
  */
@@ -79,8 +80,7 @@ var EntityCreateCommand = /** @class */ (function () {
79
80
  return [3 /*break*/, 8];
80
81
  case 7:
81
82
  err_2 = _a.sent();
82
- console.log(chalk_1.default.black.bgRed("Error during entity creation:"));
83
- console.error(err_2);
83
+ PlatformTools_1.PlatformTools.logCmdErr("Error during entity creation:", err_2);
84
84
  process.exit(1);
85
85
  return [3 /*break*/, 8];
86
86
  case 8: return [2 /*return*/];
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/commands/EntityCreateCommand.ts"],"names":[],"mappings":";;;;AAAA,iFAA8E;AAC9E,+CAA4C;AAE5C,6DAA0B;AAE1B;;GAEG;AACH;IAAA;QACI,YAAO,GAAG,eAAe,CAAC;QAC1B,aAAQ,GAAG,yBAAyB,CAAC;IA8EzC,CAAC;IA5EG,qCAAO,GAAP,UAAQ,IAAgB;QACpB,OAAO,IAAI;aACN,MAAM,CAAC,GAAG,EAAE;YACT,KAAK,EAAE,YAAY;YACnB,OAAO,EAAE,SAAS;YAClB,QAAQ,EAAE,gDAAgD;SAC7D,CAAC;aACD,MAAM,CAAC,GAAG,EAAE;YACT,KAAK,EAAE,MAAM;YACb,QAAQ,EAAE,2BAA2B;YACrC,MAAM,EAAE,IAAI;SACf,CAAC;aACD,MAAM,CAAC,GAAG,EAAE;YACT,KAAK,EAAE,KAAK;YACZ,QAAQ,EAAE,2CAA2C;SACxD,CAAC;aACD,MAAM,CAAC,GAAG,EAAE;YACT,KAAK,EAAE,QAAQ;YACf,OAAO,EAAE,WAAW;YACpB,QAAQ,EAAE,iDAAiD;SAC9D,CAAC,CAAC;IACX,CAAC;IAEK,qCAAO,GAAb,UAAc,IAAqB;;;;;;;wBAErB,WAAW,GAAG,mBAAmB,CAAC,WAAW,CAAC,IAAI,CAAC,IAAW,CAAC,CAAC;wBAChE,QAAQ,GAAG,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;wBAC/B,SAAS,GAAG,IAAI,CAAC,GAAyB,CAAC;6BAG3C,CAAC,SAAS,EAAV,wBAAU;;;;wBAEA,uBAAuB,GAAG,IAAI,iDAAuB,CAAC;4BACxD,IAAI,EAAE,OAAO,CAAC,GAAG,EAAE;4BACnB,UAAU,EAAE,IAAI,CAAC,MAAa;yBACjC,CAAC,CAAC;wBACuB,qBAAM,uBAAuB,CAAC,GAAG,CAAC,IAAI,CAAC,UAAiB,CAAC,EAAA;;wBAA7E,iBAAiB,GAAG,SAAyD;wBACnF,SAAS,GAAG,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,GAAG,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;;;;;;wBAI3F,IAAI,SAAS,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;4BACzC,SAAS,GAAG,OAAO,CAAC,GAAG,EAAE,GAAG,GAAG,GAAG,SAAS,CAAC;yBAC/C;wBACK,IAAI,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC;wBAC1C,qBAAM,2BAAY,CAAC,UAAU,CAAC,IAAI,CAAC,EAAA;;wBAAhD,UAAU,GAAG,SAAmC;wBACtD,IAAI,UAAU,EAAE;4BACZ,MAAM,UAAQ,eAAK,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAiB,CAAC;yBACnD;wBACD,qBAAM,2BAAY,CAAC,UAAU,CAAC,IAAI,EAAE,WAAW,CAAC,EAAA;;wBAAhD,SAAgD,CAAC;wBACjD,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,YAAU,eAAK,CAAC,IAAI,CAAC,IAAI,CAAC,oCAAiC,CAAC,CAAC,CAAC;;;;wBAGtF,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,KAAK,CAAC,+BAA+B,CAAC,CAAC,CAAC;wBAChE,OAAO,CAAC,KAAK,CAAC,KAAG,CAAC,CAAC;wBACnB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;;;;;;KAEvB;IAED,4EAA4E;IAC5E,2BAA2B;IAC3B,4EAA4E;IAE5E;;OAEG;IACc,+BAAW,GAA5B,UAA6B,IAAY;QACrC,OAAO,kEAGA,IAAI,cAGlB,CAAC;IACE,CAAC;IAEL,0BAAC;AAAD,CAhFA,AAgFC,IAAA;AAhFY,kDAAmB","file":"EntityCreateCommand.js","sourcesContent":["import {ConnectionOptionsReader} from \"../connection/ConnectionOptionsReader\";\nimport {CommandUtils} from \"./CommandUtils\";\nimport * as yargs from \"yargs\";\nimport chalk from \"chalk\";\n\n/**\n * Generates a new entity.\n */\nexport class EntityCreateCommand implements yargs.CommandModule {\n command = \"entity:create\";\n describe = \"Generates a new entity.\";\n\n builder(args: yargs.Argv) {\n return args\n .option(\"c\", {\n alias: \"connection\",\n default: \"default\",\n describe: \"Name of the connection on which to run a query\"\n })\n .option(\"n\", {\n alias: \"name\",\n describe: \"Name of the entity class.\",\n demand: true\n })\n .option(\"d\", {\n alias: \"dir\",\n describe: \"Directory where entity should be created.\"\n })\n .option(\"f\", {\n alias: \"config\",\n default: \"ormconfig\",\n describe: \"Name of the file with connection configuration.\"\n });\n }\n\n async handler(args: yargs.Arguments) {\n try {\n const fileContent = EntityCreateCommand.getTemplate(args.name as any);\n const filename = args.name + \".ts\";\n let directory = args.dir as string | undefined;\n\n // if directory is not set then try to open tsconfig and find default path there\n if (!directory) {\n try {\n const connectionOptionsReader = new ConnectionOptionsReader({\n root: process.cwd(),\n configName: args.config as any\n });\n const connectionOptions = await connectionOptionsReader.get(args.connection as any);\n directory = connectionOptions.cli ? (connectionOptions.cli.entitiesDir || \"\") : \"\";\n } catch (err) { }\n }\n\n if (directory && !directory.startsWith(\"/\")) {\n directory = process.cwd() + \"/\" + directory;\n }\n const path = (directory ? (directory + \"/\") : \"\") + filename;\n const fileExists = await CommandUtils.fileExists(path);\n if (fileExists) {\n throw `File ${chalk.blue(path)} already exists`;\n }\n await CommandUtils.createFile(path, fileContent);\n console.log(chalk.green(`Entity ${chalk.blue(path)} has been created successfully.`));\n\n } catch (err) {\n console.log(chalk.black.bgRed(\"Error during entity creation:\"));\n console.error(err);\n process.exit(1);\n }\n }\n\n // -------------------------------------------------------------------------\n // Protected Static Methods\n // -------------------------------------------------------------------------\n\n /**\n * Gets contents of the entity file.\n */\n protected static getTemplate(name: string): string {\n return `import {Entity} from \"typeorm\";\n\n@Entity()\nexport class ${name} {\n\n}\n`;\n }\n\n}\n"],"sourceRoot":".."}
1
+ {"version":3,"sources":["../../src/commands/EntityCreateCommand.ts"],"names":[],"mappings":";;;;AAAA,iFAA8E;AAC9E,+CAA4C;AAE5C,6DAA0B;AAC1B,2DAA0D;AAE1D;;GAEG;AACH;IAAA;QACI,YAAO,GAAG,eAAe,CAAC;QAC1B,aAAQ,GAAG,yBAAyB,CAAC;IA6EzC,CAAC;IA3EG,qCAAO,GAAP,UAAQ,IAAgB;QACpB,OAAO,IAAI;aACN,MAAM,CAAC,GAAG,EAAE;YACT,KAAK,EAAE,YAAY;YACnB,OAAO,EAAE,SAAS;YAClB,QAAQ,EAAE,gDAAgD;SAC7D,CAAC;aACD,MAAM,CAAC,GAAG,EAAE;YACT,KAAK,EAAE,MAAM;YACb,QAAQ,EAAE,2BAA2B;YACrC,MAAM,EAAE,IAAI;SACf,CAAC;aACD,MAAM,CAAC,GAAG,EAAE;YACT,KAAK,EAAE,KAAK;YACZ,QAAQ,EAAE,2CAA2C;SACxD,CAAC;aACD,MAAM,CAAC,GAAG,EAAE;YACT,KAAK,EAAE,QAAQ;YACf,OAAO,EAAE,WAAW;YACpB,QAAQ,EAAE,iDAAiD;SAC9D,CAAC,CAAC;IACX,CAAC;IAEK,qCAAO,GAAb,UAAc,IAAqB;;;;;;;wBAErB,WAAW,GAAG,mBAAmB,CAAC,WAAW,CAAC,IAAI,CAAC,IAAW,CAAC,CAAC;wBAChE,QAAQ,GAAG,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;wBAC/B,SAAS,GAAG,IAAI,CAAC,GAAyB,CAAC;6BAG3C,CAAC,SAAS,EAAV,wBAAU;;;;wBAEA,uBAAuB,GAAG,IAAI,iDAAuB,CAAC;4BACxD,IAAI,EAAE,OAAO,CAAC,GAAG,EAAE;4BACnB,UAAU,EAAE,IAAI,CAAC,MAAa;yBACjC,CAAC,CAAC;wBACuB,qBAAM,uBAAuB,CAAC,GAAG,CAAC,IAAI,CAAC,UAAiB,CAAC,EAAA;;wBAA7E,iBAAiB,GAAG,SAAyD;wBACnF,SAAS,GAAG,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,GAAG,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;;;;;;wBAI3F,IAAI,SAAS,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;4BACzC,SAAS,GAAG,OAAO,CAAC,GAAG,EAAE,GAAG,GAAG,GAAG,SAAS,CAAC;yBAC/C;wBACK,IAAI,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC;wBAC1C,qBAAM,2BAAY,CAAC,UAAU,CAAC,IAAI,CAAC,EAAA;;wBAAhD,UAAU,GAAG,SAAmC;wBACtD,IAAI,UAAU,EAAE;4BACZ,MAAM,UAAQ,eAAK,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAiB,CAAC;yBACnD;wBACD,qBAAM,2BAAY,CAAC,UAAU,CAAC,IAAI,EAAE,WAAW,CAAC,EAAA;;wBAAhD,SAAgD,CAAC;wBACjD,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,YAAU,eAAK,CAAC,IAAI,CAAC,IAAI,CAAC,oCAAiC,CAAC,CAAC,CAAC;;;;wBAGtF,6BAAa,CAAC,SAAS,CAAC,+BAA+B,EAAE,KAAG,CAAC,CAAC;wBAC9D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;;;;;;KAEvB;IAED,4EAA4E;IAC5E,2BAA2B;IAC3B,4EAA4E;IAE5E;;OAEG;IACc,+BAAW,GAA5B,UAA6B,IAAY;QACrC,OAAO,kEAGA,IAAI,cAGlB,CAAC;IACE,CAAC;IAEL,0BAAC;AAAD,CA/EA,AA+EC,IAAA;AA/EY,kDAAmB","file":"EntityCreateCommand.js","sourcesContent":["import {ConnectionOptionsReader} from \"../connection/ConnectionOptionsReader\";\nimport {CommandUtils} from \"./CommandUtils\";\nimport * as yargs from \"yargs\";\nimport chalk from \"chalk\";\nimport { PlatformTools } from \"../platform/PlatformTools\";\n\n/**\n * Generates a new entity.\n */\nexport class EntityCreateCommand implements yargs.CommandModule {\n command = \"entity:create\";\n describe = \"Generates a new entity.\";\n\n builder(args: yargs.Argv) {\n return args\n .option(\"c\", {\n alias: \"connection\",\n default: \"default\",\n describe: \"Name of the connection on which to run a query\"\n })\n .option(\"n\", {\n alias: \"name\",\n describe: \"Name of the entity class.\",\n demand: true\n })\n .option(\"d\", {\n alias: \"dir\",\n describe: \"Directory where entity should be created.\"\n })\n .option(\"f\", {\n alias: \"config\",\n default: \"ormconfig\",\n describe: \"Name of the file with connection configuration.\"\n });\n }\n\n async handler(args: yargs.Arguments) {\n try {\n const fileContent = EntityCreateCommand.getTemplate(args.name as any);\n const filename = args.name + \".ts\";\n let directory = args.dir as string | undefined;\n\n // if directory is not set then try to open tsconfig and find default path there\n if (!directory) {\n try {\n const connectionOptionsReader = new ConnectionOptionsReader({\n root: process.cwd(),\n configName: args.config as any\n });\n const connectionOptions = await connectionOptionsReader.get(args.connection as any);\n directory = connectionOptions.cli ? (connectionOptions.cli.entitiesDir || \"\") : \"\";\n } catch (err) { }\n }\n\n if (directory && !directory.startsWith(\"/\")) {\n directory = process.cwd() + \"/\" + directory;\n }\n const path = (directory ? (directory + \"/\") : \"\") + filename;\n const fileExists = await CommandUtils.fileExists(path);\n if (fileExists) {\n throw `File ${chalk.blue(path)} already exists`;\n }\n await CommandUtils.createFile(path, fileContent);\n console.log(chalk.green(`Entity ${chalk.blue(path)} has been created successfully.`));\n\n } catch (err) {\n PlatformTools.logCmdErr(\"Error during entity creation:\", err);\n process.exit(1);\n }\n }\n\n // -------------------------------------------------------------------------\n // Protected Static Methods\n // -------------------------------------------------------------------------\n\n /**\n * Gets contents of the entity file.\n */\n protected static getTemplate(name: string): string {\n return `import {Entity} from \"typeorm\";\n\n@Entity()\nexport class ${name} {\n\n}\n`;\n }\n\n}\n"],"sourceRoot":".."}
@@ -17,9 +17,11 @@ export declare class InitCommand implements yargs.CommandModule {
17
17
  docker: unknown;
18
18
  } & {
19
19
  pm: string;
20
+ } & {
21
+ ms: string;
20
22
  }>;
21
23
  handler(args: yargs.Arguments): Promise<void>;
22
- protected static executeCommand(command: string): Promise<string>;
24
+ protected static executeCommand(command: string, cwd: string): Promise<string>;
23
25
  /**
24
26
  * Gets contents of the ormconfig file.
25
27
  */
@@ -27,7 +29,7 @@ export declare class InitCommand implements yargs.CommandModule {
27
29
  /**
28
30
  * Gets contents of the ormconfig file.
29
31
  */
30
- protected static getTsConfigTemplate(): string;
32
+ protected static getTsConfigTemplate(esmModule: boolean): string;
31
33
  /**
32
34
  * Gets contents of the .gitignore file.
33
35
  */
@@ -39,19 +41,19 @@ export declare class InitCommand implements yargs.CommandModule {
39
41
  /**
40
42
  * Gets contents of the route file (used when express is enabled).
41
43
  */
42
- protected static getRoutesTemplate(): string;
44
+ protected static getRoutesTemplate(isEsm: boolean): string;
43
45
  /**
44
46
  * Gets contents of the user controller file (used when express is enabled).
45
47
  */
46
- protected static getControllerTemplate(): string;
48
+ protected static getControllerTemplate(isEsm: boolean): string;
47
49
  /**
48
50
  * Gets contents of the main (index) application file.
49
51
  */
50
- protected static getAppIndexTemplate(express: boolean): string;
52
+ protected static getAppIndexTemplate(express: boolean, isEsm: boolean): string;
51
53
  /**
52
54
  * Gets contents of the new package.json file.
53
55
  */
54
- protected static getPackageJsonTemplate(projectName?: string): string;
56
+ protected static getPackageJsonTemplate(projectName?: string, projectIsEsm?: boolean): string;
55
57
  /**
56
58
  * Gets contents of the new docker-compose.yml file.
57
59
  */
@@ -65,5 +67,5 @@ export declare class InitCommand implements yargs.CommandModule {
65
67
  /**
66
68
  * Appends to a given package.json template everything needed.
67
69
  */
68
- protected static appendPackageJson(packageJsonContents: string, database: string, express: boolean): string;
70
+ protected static appendPackageJson(packageJsonContents: string, database: string, express: boolean, projectIsEsm: boolean): string;
69
71
  }
@@ -7,6 +7,7 @@ var path = (0, tslib_1.__importStar)(require("path"));
7
7
  var chalk_1 = (0, tslib_1.__importDefault)(require("chalk"));
8
8
  var child_process_1 = require("child_process");
9
9
  var TypeORMError_1 = require("../error/TypeORMError");
10
+ var PlatformTools_1 = require("../platform/PlatformTools");
10
11
  /**
11
12
  * Generates a new project with TypeORM.
12
13
  */
@@ -43,11 +44,17 @@ var InitCommand = /** @class */ (function () {
43
44
  choices: ["npm", "yarn"],
44
45
  default: "npm",
45
46
  describe: "Install packages, expected values are npm or yarn."
47
+ })
48
+ .option("ms", {
49
+ alias: "module",
50
+ choices: ["commonjs", "esm"],
51
+ default: "commonjs",
52
+ describe: "Module system to use for project, expected values are commonjs or esm."
46
53
  });
47
54
  };
48
55
  InitCommand.prototype.handler = function (args) {
49
56
  return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
50
- var database, isExpress, isDocker, basePath, projectName, installNpm, packageJsonContents, err_1;
57
+ var database, isExpress, isDocker, basePath, projectName, installNpm, projectIsEsm, packageJsonContents, err_1;
51
58
  return (0, tslib_1.__generator)(this, function (_a) {
52
59
  switch (_a.label) {
53
60
  case 0:
@@ -58,7 +65,8 @@ var InitCommand = /** @class */ (function () {
58
65
  basePath = process.cwd() + (args.name ? ("/" + args.name) : "");
59
66
  projectName = args.name ? path.basename(args.name) : undefined;
60
67
  installNpm = args.pm === "yarn" ? false : true;
61
- return [4 /*yield*/, CommandUtils_1.CommandUtils.createFile(basePath + "/package.json", InitCommand.getPackageJsonTemplate(projectName), false)];
68
+ projectIsEsm = args.ms === "esm";
69
+ return [4 /*yield*/, CommandUtils_1.CommandUtils.createFile(basePath + "/package.json", InitCommand.getPackageJsonTemplate(projectName, projectIsEsm), false)];
62
70
  case 1:
63
71
  _a.sent();
64
72
  if (!isDocker) return [3 /*break*/, 3];
@@ -72,7 +80,7 @@ var InitCommand = /** @class */ (function () {
72
80
  return [4 /*yield*/, CommandUtils_1.CommandUtils.createFile(basePath + "/README.md", InitCommand.getReadmeTemplate({ docker: isDocker }), false)];
73
81
  case 5:
74
82
  _a.sent();
75
- return [4 /*yield*/, CommandUtils_1.CommandUtils.createFile(basePath + "/tsconfig.json", InitCommand.getTsConfigTemplate())];
83
+ return [4 /*yield*/, CommandUtils_1.CommandUtils.createFile(basePath + "/tsconfig.json", InitCommand.getTsConfigTemplate(projectIsEsm))];
76
84
  case 6:
77
85
  _a.sent();
78
86
  return [4 /*yield*/, CommandUtils_1.CommandUtils.createFile(basePath + "/ormconfig.json", InitCommand.getOrmConfigTemplate(database))];
@@ -81,24 +89,24 @@ var InitCommand = /** @class */ (function () {
81
89
  return [4 /*yield*/, CommandUtils_1.CommandUtils.createFile(basePath + "/src/entity/User.ts", InitCommand.getUserEntityTemplate(database))];
82
90
  case 8:
83
91
  _a.sent();
84
- return [4 /*yield*/, CommandUtils_1.CommandUtils.createFile(basePath + "/src/index.ts", InitCommand.getAppIndexTemplate(isExpress))];
92
+ return [4 /*yield*/, CommandUtils_1.CommandUtils.createFile(basePath + "/src/index.ts", InitCommand.getAppIndexTemplate(isExpress, projectIsEsm))];
85
93
  case 9:
86
94
  _a.sent();
87
95
  return [4 /*yield*/, CommandUtils_1.CommandUtils.createDirectories(basePath + "/src/migration")];
88
96
  case 10:
89
97
  _a.sent();
90
98
  if (!isExpress) return [3 /*break*/, 13];
91
- return [4 /*yield*/, CommandUtils_1.CommandUtils.createFile(basePath + "/src/routes.ts", InitCommand.getRoutesTemplate())];
99
+ return [4 /*yield*/, CommandUtils_1.CommandUtils.createFile(basePath + "/src/routes.ts", InitCommand.getRoutesTemplate(projectIsEsm))];
92
100
  case 11:
93
101
  _a.sent();
94
- return [4 /*yield*/, CommandUtils_1.CommandUtils.createFile(basePath + "/src/controller/UserController.ts", InitCommand.getControllerTemplate())];
102
+ return [4 /*yield*/, CommandUtils_1.CommandUtils.createFile(basePath + "/src/controller/UserController.ts", InitCommand.getControllerTemplate(projectIsEsm))];
95
103
  case 12:
96
104
  _a.sent();
97
105
  _a.label = 13;
98
106
  case 13: return [4 /*yield*/, CommandUtils_1.CommandUtils.readFile(basePath + "/package.json")];
99
107
  case 14:
100
108
  packageJsonContents = _a.sent();
101
- return [4 /*yield*/, CommandUtils_1.CommandUtils.createFile(basePath + "/package.json", InitCommand.appendPackageJson(packageJsonContents, database, isExpress))];
109
+ return [4 /*yield*/, CommandUtils_1.CommandUtils.createFile(basePath + "/package.json", InitCommand.appendPackageJson(packageJsonContents, database, isExpress, projectIsEsm))];
102
110
  case 15:
103
111
  _a.sent();
104
112
  if (args.name) {
@@ -108,19 +116,18 @@ var InitCommand = /** @class */ (function () {
108
116
  console.log(chalk_1.default.green("Project created inside current directory."));
109
117
  }
110
118
  if (!(args.pm && installNpm)) return [3 /*break*/, 17];
111
- return [4 /*yield*/, InitCommand.executeCommand("npm install")];
119
+ return [4 /*yield*/, InitCommand.executeCommand("npm install", basePath)];
112
120
  case 16:
113
121
  _a.sent();
114
122
  return [3 /*break*/, 19];
115
- case 17: return [4 /*yield*/, InitCommand.executeCommand("yarn install")];
123
+ case 17: return [4 /*yield*/, InitCommand.executeCommand("yarn install", basePath)];
116
124
  case 18:
117
125
  _a.sent();
118
126
  _a.label = 19;
119
127
  case 19: return [3 /*break*/, 21];
120
128
  case 20:
121
129
  err_1 = _a.sent();
122
- console.log(chalk_1.default.black.bgRed("Error during project initialization:"));
123
- console.error(err_1);
130
+ PlatformTools_1.PlatformTools.logCmdErr("Error during project initialization:", err_1);
124
131
  process.exit(1);
125
132
  return [3 /*break*/, 21];
126
133
  case 21: return [2 /*return*/];
@@ -131,9 +138,9 @@ var InitCommand = /** @class */ (function () {
131
138
  // -------------------------------------------------------------------------
132
139
  // Protected Static Methods
133
140
  // -------------------------------------------------------------------------
134
- InitCommand.executeCommand = function (command) {
141
+ InitCommand.executeCommand = function (command, cwd) {
135
142
  return new Promise(function (ok, fail) {
136
- (0, child_process_1.exec)(command, function (error, stdout, stderr) {
143
+ (0, child_process_1.exec)(command, { cwd: cwd }, function (error, stdout, stderr) {
137
144
  if (stdout)
138
145
  return ok(stdout);
139
146
  if (stderr)
@@ -251,19 +258,34 @@ var InitCommand = /** @class */ (function () {
251
258
  /**
252
259
  * Gets contents of the ormconfig file.
253
260
  */
254
- InitCommand.getTsConfigTemplate = function () {
255
- return JSON.stringify({
256
- compilerOptions: {
257
- lib: ["es5", "es6"],
258
- target: "es5",
259
- module: "commonjs",
260
- moduleResolution: "node",
261
- outDir: "./build",
262
- emitDecoratorMetadata: true,
263
- experimentalDecorators: true,
264
- sourceMap: true
265
- }
266
- }, undefined, 3);
261
+ InitCommand.getTsConfigTemplate = function (esmModule) {
262
+ if (esmModule)
263
+ return JSON.stringify({
264
+ compilerOptions: {
265
+ lib: ["es2021"],
266
+ target: "es2021",
267
+ module: "es2022",
268
+ moduleResolution: "node",
269
+ allowSyntheticDefaultImports: true,
270
+ outDir: "./build",
271
+ emitDecoratorMetadata: true,
272
+ experimentalDecorators: true,
273
+ sourceMap: true
274
+ }
275
+ }, undefined, 3);
276
+ else
277
+ return JSON.stringify({
278
+ compilerOptions: {
279
+ lib: ["es5", "es6"],
280
+ target: "es5",
281
+ module: "commonjs",
282
+ moduleResolution: "node",
283
+ outDir: "./build",
284
+ emitDecoratorMetadata: true,
285
+ experimentalDecorators: true,
286
+ sourceMap: true
287
+ }
288
+ }, undefined, 3);
267
289
  };
268
290
  /**
269
291
  * Gets contents of the .gitignore file.
@@ -280,34 +302,35 @@ var InitCommand = /** @class */ (function () {
280
302
  /**
281
303
  * Gets contents of the route file (used when express is enabled).
282
304
  */
283
- InitCommand.getRoutesTemplate = function () {
284
- return "import {UserController} from \"./controller/UserController\";\n\nexport const Routes = [{\n method: \"get\",\n route: \"/users\",\n controller: UserController,\n action: \"all\"\n}, {\n method: \"get\",\n route: \"/users/:id\",\n controller: UserController,\n action: \"one\"\n}, {\n method: \"post\",\n route: \"/users\",\n controller: UserController,\n action: \"save\"\n}, {\n method: \"delete\",\n route: \"/users/:id\",\n controller: UserController,\n action: \"remove\"\n}];";
305
+ InitCommand.getRoutesTemplate = function (isEsm) {
306
+ return "import {UserController} from \"./controller/UserController" + (isEsm ? ".js" : "") + "\";\n\nexport const Routes = [{\n method: \"get\",\n route: \"/users\",\n controller: UserController,\n action: \"all\"\n}, {\n method: \"get\",\n route: \"/users/:id\",\n controller: UserController,\n action: \"one\"\n}, {\n method: \"post\",\n route: \"/users\",\n controller: UserController,\n action: \"save\"\n}, {\n method: \"delete\",\n route: \"/users/:id\",\n controller: UserController,\n action: \"remove\"\n}];";
285
307
  };
286
308
  /**
287
309
  * Gets contents of the user controller file (used when express is enabled).
288
310
  */
289
- InitCommand.getControllerTemplate = function () {
290
- return "import {getRepository} from \"typeorm\";\nimport {NextFunction, Request, Response} from \"express\";\nimport {User} from \"../entity/User\";\n\nexport class UserController {\n\n private userRepository = getRepository(User);\n\n async all(request: Request, response: Response, next: NextFunction) {\n return this.userRepository.find();\n }\n\n async one(request: Request, response: Response, next: NextFunction) {\n return this.userRepository.findOne(request.params.id);\n }\n\n async save(request: Request, response: Response, next: NextFunction) {\n return this.userRepository.save(request.body);\n }\n\n async remove(request: Request, response: Response, next: NextFunction) {\n let userToRemove = await this.userRepository.findOne(request.params.id);\n await this.userRepository.remove(userToRemove);\n }\n\n}";
311
+ InitCommand.getControllerTemplate = function (isEsm) {
312
+ return "import {getRepository} from \"typeorm\";\nimport {NextFunction, Request, Response} from \"express\";\nimport {User} from \"../entity/User" + (isEsm ? ".js" : "") + "\";\n\nexport class UserController {\n\n private userRepository = getRepository(User);\n\n async all(request: Request, response: Response, next: NextFunction) {\n return this.userRepository.find();\n }\n\n async one(request: Request, response: Response, next: NextFunction) {\n return this.userRepository.findOne(request.params.id);\n }\n\n async save(request: Request, response: Response, next: NextFunction) {\n return this.userRepository.save(request.body);\n }\n\n async remove(request: Request, response: Response, next: NextFunction) {\n let userToRemove = await this.userRepository.findOne(request.params.id);\n await this.userRepository.remove(userToRemove);\n }\n\n}";
291
313
  };
292
314
  /**
293
315
  * Gets contents of the main (index) application file.
294
316
  */
295
- InitCommand.getAppIndexTemplate = function (express) {
317
+ InitCommand.getAppIndexTemplate = function (express, isEsm) {
296
318
  if (express) {
297
- return "import \"reflect-metadata\";\nimport {createConnection} from \"typeorm\";\nimport * as express from \"express\";\nimport * as bodyParser from \"body-parser\";\nimport {Request, Response} from \"express\";\nimport {Routes} from \"./routes\";\nimport {User} from \"./entity/User\";\n\ncreateConnection().then(async connection => {\n\n // create express app\n const app = express();\n app.use(bodyParser.json());\n\n // register express routes from defined application routes\n Routes.forEach(route => {\n (app as any)[route.method](route.route, (req: Request, res: Response, next: Function) => {\n const result = (new (route.controller as any))[route.action](req, res, next);\n if (result instanceof Promise) {\n result.then(result => result !== null && result !== undefined ? res.send(result) : undefined);\n\n } else if (result !== null && result !== undefined) {\n res.json(result);\n }\n });\n });\n\n // setup express app here\n // ...\n\n // start express server\n app.listen(3000);\n\n // insert new users for test\n await connection.manager.save(connection.manager.create(User, {\n firstName: \"Timber\",\n lastName: \"Saw\",\n age: 27\n }));\n await connection.manager.save(connection.manager.create(User, {\n firstName: \"Phantom\",\n lastName: \"Assassin\",\n age: 24\n }));\n\n console.log(\"Express server has started on port 3000. Open http://localhost:3000/users to see results\");\n\n}).catch(error => console.log(error));\n";
319
+ return "import \"reflect-metadata\";\nimport {createConnection} from \"typeorm\";\nimport " + (!isEsm ? "* as " : "") + "express from \"express\";\nimport " + (!isEsm ? "* as " : "") + "bodyParser from \"body-parser\";\nimport {Request, Response} from \"express\";\nimport {Routes} from \"./routes" + (isEsm ? ".js" : "") + "\";\nimport {User} from \"./entity/User" + (isEsm ? ".js" : "") + "\";\n\ncreateConnection().then(async connection => {\n\n // create express app\n const app = express();\n app.use(bodyParser.json());\n\n // register express routes from defined application routes\n Routes.forEach(route => {\n (app as any)[route.method](route.route, (req: Request, res: Response, next: Function) => {\n const result = (new (route.controller as any))[route.action](req, res, next);\n if (result instanceof Promise) {\n result.then(result => result !== null && result !== undefined ? res.send(result) : undefined);\n\n } else if (result !== null && result !== undefined) {\n res.json(result);\n }\n });\n });\n\n // setup express app here\n // ...\n\n // start express server\n app.listen(3000);\n\n // insert new users for test\n await connection.manager.save(connection.manager.create(User, {\n firstName: \"Timber\",\n lastName: \"Saw\",\n age: 27\n }));\n await connection.manager.save(connection.manager.create(User, {\n firstName: \"Phantom\",\n lastName: \"Assassin\",\n age: 24\n }));\n\n console.log(\"Express server has started on port 3000. Open http://localhost:3000/users to see results\");\n\n}).catch(error => console.log(error));\n";
298
320
  }
299
321
  else {
300
- return "import \"reflect-metadata\";\nimport {createConnection} from \"typeorm\";\nimport {User} from \"./entity/User\";\n\ncreateConnection().then(async connection => {\n\n console.log(\"Inserting a new user into the database...\");\n const user = new User();\n user.firstName = \"Timber\";\n user.lastName = \"Saw\";\n user.age = 25;\n await connection.manager.save(user);\n console.log(\"Saved a new user with id: \" + user.id);\n\n console.log(\"Loading users from the database...\");\n const users = await connection.manager.find(User);\n console.log(\"Loaded users: \", users);\n\n console.log(\"Here you can setup and run express/koa/any other framework.\");\n\n}).catch(error => console.log(error));\n";
322
+ return "import \"reflect-metadata\";\nimport {createConnection} from \"typeorm\";\nimport {User} from \"./entity/User" + (isEsm ? ".js" : "") + "\";\n\ncreateConnection().then(async connection => {\n\n console.log(\"Inserting a new user into the database...\");\n const user = new User();\n user.firstName = \"Timber\";\n user.lastName = \"Saw\";\n user.age = 25;\n await connection.manager.save(user);\n console.log(\"Saved a new user with id: \" + user.id);\n\n console.log(\"Loading users from the database...\");\n const users = await connection.manager.find(User);\n console.log(\"Loaded users: \", users);\n\n console.log(\"Here you can setup and run express/koa/any other framework.\");\n\n}).catch(error => console.log(error));\n";
301
323
  }
302
324
  };
303
325
  /**
304
326
  * Gets contents of the new package.json file.
305
327
  */
306
- InitCommand.getPackageJsonTemplate = function (projectName) {
328
+ InitCommand.getPackageJsonTemplate = function (projectName, projectIsEsm) {
307
329
  return JSON.stringify({
308
330
  name: projectName || "new-typeorm-project",
309
331
  version: "0.0.1",
310
332
  description: "Awesome project developed with TypeORM.",
333
+ type: projectIsEsm ? "module" : "commonjs",
311
334
  devDependencies: {},
312
335
  dependencies: {},
313
336
  scripts: {}
@@ -355,20 +378,20 @@ var InitCommand = /** @class */ (function () {
355
378
  /**
356
379
  * Appends to a given package.json template everything needed.
357
380
  */
358
- InitCommand.appendPackageJson = function (packageJsonContents, database, express /*, docker: boolean*/) {
381
+ InitCommand.appendPackageJson = function (packageJsonContents, database, express, projectIsEsm /*, docker: boolean*/) {
359
382
  var packageJson = JSON.parse(packageJsonContents);
360
383
  if (!packageJson.devDependencies)
361
384
  packageJson.devDependencies = {};
362
385
  Object.assign(packageJson.devDependencies, {
363
- "ts-node": "3.3.0",
364
- "@types/node": "^8.0.29",
365
- "typescript": "3.3.3333"
386
+ "ts-node": "10.4.0",
387
+ "@types/node": "^16.11.10",
388
+ "typescript": "4.5.2"
366
389
  });
367
390
  if (!packageJson.dependencies)
368
391
  packageJson.dependencies = {};
369
392
  Object.assign(packageJson.dependencies, {
370
393
  "typeorm": require("../package.json").version,
371
- "reflect-metadata": "^0.1.10"
394
+ "reflect-metadata": "^0.1.13"
372
395
  });
373
396
  switch (database) {
374
397
  case "mysql":
@@ -396,15 +419,21 @@ var InitCommand = /** @class */ (function () {
396
419
  break;
397
420
  }
398
421
  if (express) {
399
- packageJson.dependencies["express"] = "^4.15.4";
400
- packageJson.dependencies["body-parser"] = "^1.18.1";
422
+ packageJson.dependencies["express"] = "^4.17.2";
423
+ packageJson.dependencies["body-parser"] = "^1.19.1";
401
424
  }
402
425
  if (!packageJson.scripts)
403
426
  packageJson.scripts = {};
404
- Object.assign(packageJson.scripts, {
405
- start: /*(docker ? "docker-compose up && " : "") + */ "ts-node src/index.ts",
406
- typeorm: "node --require ts-node/register ./node_modules/typeorm/cli.js"
407
- });
427
+ if (projectIsEsm)
428
+ Object.assign(packageJson.scripts, {
429
+ start: /*(docker ? "docker-compose up && " : "") + */ "node --loader ts-node/esm src/index.ts",
430
+ typeorm: "node --loader ts-node/esm ./node_modules/typeorm/cli.js"
431
+ });
432
+ else
433
+ Object.assign(packageJson.scripts, {
434
+ start: /*(docker ? "docker-compose up && " : "") + */ "ts-node src/index.ts",
435
+ typeorm: "node --require ts-node/register ./node_modules/typeorm/cli.js"
436
+ });
408
437
  return JSON.stringify(packageJson, undefined, 3);
409
438
  };
410
439
  return InitCommand;