typeorm 0.3.6-dev.9d331b1 → 0.3.6-dev.bbdc20f

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 (370) hide show
  1. package/README.md +34 -14
  2. package/browser/cache/DbQueryResultCache.js +9 -1
  3. package/browser/cache/DbQueryResultCache.js.map +1 -1
  4. package/browser/cache/RedisQueryResultCache.js +3 -0
  5. package/browser/cache/RedisQueryResultCache.js.map +1 -1
  6. package/browser/data-source/DataSourceOptions.d.ts +2 -1
  7. package/browser/data-source/DataSourceOptions.js.map +1 -1
  8. package/browser/decorator/Index.js +1 -0
  9. package/browser/decorator/Index.js.map +1 -1
  10. package/browser/decorator/columns/PrimaryColumn.js +4 -1
  11. package/browser/decorator/columns/PrimaryColumn.js.map +1 -1
  12. package/browser/decorator/options/ColumnOptions.d.ts +10 -2
  13. package/browser/decorator/options/ColumnOptions.js.map +1 -1
  14. package/browser/decorator/options/IndexOptions.d.ts +8 -0
  15. package/browser/decorator/options/IndexOptions.js.map +1 -1
  16. package/browser/decorator/options/JoinColumnOptions.d.ts +4 -0
  17. package/browser/decorator/options/JoinColumnOptions.js.map +1 -1
  18. package/browser/decorator/options/PrimaryGeneratedColumnIdentityOptions.d.ts +4 -0
  19. package/browser/decorator/options/PrimaryGeneratedColumnIdentityOptions.js.map +1 -1
  20. package/browser/decorator/options/PrimaryGeneratedColumnNumericOptions.d.ts +4 -0
  21. package/browser/decorator/options/PrimaryGeneratedColumnNumericOptions.js.map +1 -1
  22. package/browser/decorator/options/PrimaryGeneratedColumnUUIDOptions.d.ts +4 -0
  23. package/browser/decorator/options/PrimaryGeneratedColumnUUIDOptions.js.map +1 -1
  24. package/browser/decorator/relations/JoinColumn.js +1 -0
  25. package/browser/decorator/relations/JoinColumn.js.map +1 -1
  26. package/browser/driver/DriverFactory.js +4 -0
  27. package/browser/driver/DriverFactory.js.map +1 -1
  28. package/browser/driver/aurora-mysql/AuroraMysqlDriver.d.ts +1 -1
  29. package/browser/driver/aurora-mysql/AuroraMysqlDriver.js.map +1 -1
  30. package/browser/driver/cockroachdb/CockroachDriver.js +4 -1
  31. package/browser/driver/cockroachdb/CockroachDriver.js.map +1 -1
  32. package/browser/driver/cockroachdb/CockroachQueryRunner.d.ts +3 -3
  33. package/browser/driver/cockroachdb/CockroachQueryRunner.js +233 -33
  34. package/browser/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  35. package/browser/driver/mongodb/typings.d.ts +5 -5
  36. package/browser/driver/mongodb/typings.js.map +1 -1
  37. package/browser/driver/mysql/MysqlDriver.d.ts +1 -0
  38. package/browser/driver/mysql/MysqlDriver.js +94 -23
  39. package/browser/driver/mysql/MysqlDriver.js.map +1 -1
  40. package/browser/driver/mysql/MysqlQueryRunner.js +219 -24
  41. package/browser/driver/mysql/MysqlQueryRunner.js.map +1 -1
  42. package/browser/driver/oracle/OracleDriver.js +79 -15
  43. package/browser/driver/oracle/OracleDriver.js.map +1 -1
  44. package/browser/driver/oracle/OracleQueryRunner.d.ts +3 -3
  45. package/browser/driver/oracle/OracleQueryRunner.js +216 -42
  46. package/browser/driver/oracle/OracleQueryRunner.js.map +1 -1
  47. package/browser/driver/postgres/PostgresDriver.js +95 -18
  48. package/browser/driver/postgres/PostgresDriver.js.map +1 -1
  49. package/browser/driver/postgres/PostgresQueryRunner.d.ts +3 -3
  50. package/browser/driver/postgres/PostgresQueryRunner.js +159 -59
  51. package/browser/driver/postgres/PostgresQueryRunner.js.map +1 -1
  52. package/browser/driver/spanner/SpannerConnectionCredentialsOptions.d.ts +17 -0
  53. package/browser/driver/spanner/SpannerConnectionCredentialsOptions.js +3 -0
  54. package/browser/driver/spanner/SpannerConnectionCredentialsOptions.js.map +1 -0
  55. package/browser/driver/spanner/SpannerConnectionOptions.d.ts +120 -0
  56. package/browser/driver/spanner/SpannerConnectionOptions.js +3 -0
  57. package/browser/driver/spanner/SpannerConnectionOptions.js.map +1 -0
  58. package/browser/driver/spanner/SpannerDriver.d.ts +241 -0
  59. package/browser/driver/spanner/SpannerDriver.js +604 -0
  60. package/browser/driver/spanner/SpannerDriver.js.map +1 -0
  61. package/browser/driver/spanner/SpannerQueryRunner.d.ts +350 -0
  62. package/browser/driver/spanner/SpannerQueryRunner.js +1445 -0
  63. package/browser/driver/spanner/SpannerQueryRunner.js.map +1 -0
  64. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js +65 -16
  65. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  66. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +218 -32
  67. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  68. package/browser/driver/sqlserver/SqlServerDriver.d.ts +3 -1
  69. package/browser/driver/sqlserver/SqlServerDriver.js +99 -26
  70. package/browser/driver/sqlserver/SqlServerDriver.js.map +1 -1
  71. package/browser/driver/sqlserver/SqlServerQueryRunner.d.ts +3 -3
  72. package/browser/driver/sqlserver/SqlServerQueryRunner.js +251 -37
  73. package/browser/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  74. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryAccessTokenAuthentication.d.ts +1 -1
  75. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryAccessTokenAuthentication.js.map +1 -1
  76. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryMsiAppServiceAuthentication.d.ts +2 -2
  77. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryMsiAppServiceAuthentication.js.map +1 -1
  78. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryMsiVmAuthentication.d.ts +2 -2
  79. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryMsiVmAuthentication.js.map +1 -1
  80. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryPasswordAuthentication.d.ts +2 -2
  81. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryPasswordAuthentication.js.map +1 -1
  82. package/browser/driver/types/ColumnTypes.d.ts +1 -1
  83. package/browser/driver/types/ColumnTypes.js.map +1 -1
  84. package/browser/driver/types/DatabaseType.d.ts +1 -1
  85. package/browser/driver/types/DatabaseType.js.map +1 -1
  86. package/browser/entity-manager/EntityManager.js +1 -1
  87. package/browser/entity-manager/EntityManager.js.map +1 -1
  88. package/browser/entity-schema/EntitySchemaColumnOptions.d.ts +6 -2
  89. package/browser/entity-schema/EntitySchemaColumnOptions.js.map +1 -1
  90. package/browser/entity-schema/EntitySchemaIndexOptions.d.ts +8 -0
  91. package/browser/entity-schema/EntitySchemaIndexOptions.js.map +1 -1
  92. package/browser/entity-schema/EntitySchemaTransformer.js +3 -0
  93. package/browser/entity-schema/EntitySchemaTransformer.js.map +1 -1
  94. package/browser/find-options/FindOneOptions.d.ts +1 -1
  95. package/browser/find-options/FindOneOptions.js.map +1 -1
  96. package/browser/find-options/FindOptionsUtils.d.ts +2 -1
  97. package/browser/find-options/FindOptionsUtils.js +2 -1
  98. package/browser/find-options/FindOptionsUtils.js.map +1 -1
  99. package/browser/logger/AdvancedConsoleLogger.d.ts +1 -1
  100. package/browser/logger/AdvancedConsoleLogger.js +1 -1
  101. package/browser/logger/AdvancedConsoleLogger.js.map +1 -1
  102. package/browser/metadata/ColumnMetadata.d.ts +10 -2
  103. package/browser/metadata/ColumnMetadata.js +8 -0
  104. package/browser/metadata/ColumnMetadata.js.map +1 -1
  105. package/browser/metadata/EntityMetadata.js +1 -1
  106. package/browser/metadata/EntityMetadata.js.map +1 -1
  107. package/browser/metadata/ForeignKeyMetadata.d.ts +7 -0
  108. package/browser/metadata/ForeignKeyMetadata.js +4 -1
  109. package/browser/metadata/ForeignKeyMetadata.js.map +1 -1
  110. package/browser/metadata/IndexMetadata.d.ts +8 -0
  111. package/browser/metadata/IndexMetadata.js +9 -0
  112. package/browser/metadata/IndexMetadata.js.map +1 -1
  113. package/browser/metadata-args/IndexMetadataArgs.d.ts +8 -0
  114. package/browser/metadata-args/IndexMetadataArgs.js.map +1 -1
  115. package/browser/metadata-args/JoinColumnMetadataArgs.d.ts +4 -0
  116. package/browser/metadata-args/JoinColumnMetadataArgs.js.map +1 -1
  117. package/browser/metadata-builder/EntityMetadataBuilder.js +13 -6
  118. package/browser/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  119. package/browser/metadata-builder/EntityMetadataValidator.js +17 -0
  120. package/browser/metadata-builder/EntityMetadataValidator.js.map +1 -1
  121. package/browser/metadata-builder/JunctionEntityMetadataBuilder.js +18 -6
  122. package/browser/metadata-builder/JunctionEntityMetadataBuilder.js.map +1 -1
  123. package/browser/metadata-builder/RelationJoinColumnBuilder.js +2 -0
  124. package/browser/metadata-builder/RelationJoinColumnBuilder.js.map +1 -1
  125. package/browser/migration/MigrationExecutor.js +1 -1
  126. package/browser/migration/MigrationExecutor.js.map +1 -1
  127. package/browser/persistence/SubjectDatabaseEntityLoader.d.ts +1 -1
  128. package/browser/persistence/SubjectDatabaseEntityLoader.js +1 -1
  129. package/browser/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
  130. package/browser/persistence/SubjectExecutor.js +1 -1
  131. package/browser/persistence/SubjectExecutor.js.map +1 -1
  132. package/browser/persistence/subject-builder/CascadesSubjectBuilder.d.ts +1 -1
  133. package/browser/persistence/subject-builder/CascadesSubjectBuilder.js +1 -1
  134. package/browser/persistence/subject-builder/CascadesSubjectBuilder.js.map +1 -1
  135. package/browser/persistence/subject-builder/ManyToManySubjectBuilder.js +1 -1
  136. package/browser/persistence/subject-builder/ManyToManySubjectBuilder.js.map +1 -1
  137. package/browser/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js +1 -1
  138. package/browser/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js.map +1 -1
  139. package/browser/platform/PlatformTools.js +5 -0
  140. package/browser/platform/PlatformTools.js.map +1 -1
  141. package/browser/query-builder/InsertQueryBuilder.js +15 -3
  142. package/browser/query-builder/InsertQueryBuilder.js.map +1 -1
  143. package/browser/query-builder/QueryBuilder.d.ts +1 -1
  144. package/browser/query-builder/QueryBuilder.js +15 -15
  145. package/browser/query-builder/QueryBuilder.js.map +1 -1
  146. package/browser/query-builder/QueryExpressionMap.d.ts +2 -2
  147. package/browser/query-builder/QueryExpressionMap.js +1 -1
  148. package/browser/query-builder/QueryExpressionMap.js.map +1 -1
  149. package/browser/query-builder/ReturningResultsEntityUpdator.js +2 -2
  150. package/browser/query-builder/ReturningResultsEntityUpdator.js.map +1 -1
  151. package/browser/query-builder/SelectQueryBuilder.d.ts +1 -1
  152. package/browser/query-builder/SelectQueryBuilder.js +25 -4
  153. package/browser/query-builder/SelectQueryBuilder.js.map +1 -1
  154. package/browser/query-builder/UpdateQueryBuilder.js +18 -7
  155. package/browser/query-builder/UpdateQueryBuilder.js.map +1 -1
  156. package/browser/query-runner/BaseQueryRunner.d.ts +10 -0
  157. package/browser/query-runner/BaseQueryRunner.js +25 -1
  158. package/browser/query-runner/BaseQueryRunner.js.map +1 -1
  159. package/browser/query-runner/QueryRunner.d.ts +2 -2
  160. package/browser/query-runner/QueryRunner.js.map +1 -1
  161. package/browser/schema-builder/RdbmsSchemaBuilder.d.ts +6 -2
  162. package/browser/schema-builder/RdbmsSchemaBuilder.js +26 -6
  163. package/browser/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  164. package/browser/schema-builder/options/TableColumnOptions.d.ts +10 -2
  165. package/browser/schema-builder/options/TableColumnOptions.js.map +1 -1
  166. package/browser/schema-builder/options/TableForeignKeyOptions.d.ts +1 -1
  167. package/browser/schema-builder/options/TableForeignKeyOptions.js.map +1 -1
  168. package/browser/schema-builder/options/TableIndexOptions.d.ts +8 -0
  169. package/browser/schema-builder/options/TableIndexOptions.js.map +1 -1
  170. package/browser/schema-builder/table/TableColumn.d.ts +6 -2
  171. package/browser/schema-builder/table/TableColumn.js +2 -0
  172. package/browser/schema-builder/table/TableColumn.js.map +1 -1
  173. package/browser/schema-builder/table/TableIndex.d.ts +8 -0
  174. package/browser/schema-builder/table/TableIndex.js +3 -0
  175. package/browser/schema-builder/table/TableIndex.js.map +1 -1
  176. package/browser/schema-builder/util/TableUtils.js +1 -0
  177. package/browser/schema-builder/util/TableUtils.js.map +1 -1
  178. package/browser/util/OrmUtils.d.ts +1 -1
  179. package/browser/util/OrmUtils.js +4 -4
  180. package/browser/util/OrmUtils.js.map +1 -1
  181. package/browser/util/escapeRegExp.d.ts +1 -0
  182. package/browser/util/escapeRegExp.js +6 -0
  183. package/browser/util/escapeRegExp.js.map +1 -0
  184. package/cache/DbQueryResultCache.js +9 -1
  185. package/cache/DbQueryResultCache.js.map +1 -1
  186. package/cache/RedisQueryResultCache.js +3 -0
  187. package/cache/RedisQueryResultCache.js.map +1 -1
  188. package/commands/InitCommand.js +1 -1
  189. package/commands/InitCommand.js.map +1 -1
  190. package/commands/MigrationGenerateCommand.js +3 -2
  191. package/commands/MigrationGenerateCommand.js.map +1 -1
  192. package/data-source/DataSourceOptions.d.ts +2 -1
  193. package/data-source/DataSourceOptions.js.map +1 -1
  194. package/decorator/Index.js +1 -0
  195. package/decorator/Index.js.map +1 -1
  196. package/decorator/columns/PrimaryColumn.js +4 -1
  197. package/decorator/columns/PrimaryColumn.js.map +1 -1
  198. package/decorator/options/ColumnOptions.d.ts +10 -2
  199. package/decorator/options/ColumnOptions.js.map +1 -1
  200. package/decorator/options/IndexOptions.d.ts +8 -0
  201. package/decorator/options/IndexOptions.js.map +1 -1
  202. package/decorator/options/JoinColumnOptions.d.ts +4 -0
  203. package/decorator/options/JoinColumnOptions.js.map +1 -1
  204. package/decorator/options/PrimaryGeneratedColumnIdentityOptions.d.ts +4 -0
  205. package/decorator/options/PrimaryGeneratedColumnIdentityOptions.js.map +1 -1
  206. package/decorator/options/PrimaryGeneratedColumnNumericOptions.d.ts +4 -0
  207. package/decorator/options/PrimaryGeneratedColumnNumericOptions.js.map +1 -1
  208. package/decorator/options/PrimaryGeneratedColumnUUIDOptions.d.ts +4 -0
  209. package/decorator/options/PrimaryGeneratedColumnUUIDOptions.js.map +1 -1
  210. package/decorator/relations/JoinColumn.js +1 -0
  211. package/decorator/relations/JoinColumn.js.map +1 -1
  212. package/driver/DriverFactory.js +4 -0
  213. package/driver/DriverFactory.js.map +1 -1
  214. package/driver/aurora-mysql/AuroraMysqlDriver.d.ts +1 -1
  215. package/driver/aurora-mysql/AuroraMysqlDriver.js.map +1 -1
  216. package/driver/cockroachdb/CockroachDriver.js +4 -1
  217. package/driver/cockroachdb/CockroachDriver.js.map +1 -1
  218. package/driver/cockroachdb/CockroachQueryRunner.d.ts +3 -3
  219. package/driver/cockroachdb/CockroachQueryRunner.js +233 -33
  220. package/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  221. package/driver/mongodb/typings.d.ts +5 -5
  222. package/driver/mongodb/typings.js.map +1 -1
  223. package/driver/mysql/MysqlDriver.d.ts +1 -0
  224. package/driver/mysql/MysqlDriver.js +94 -23
  225. package/driver/mysql/MysqlDriver.js.map +1 -1
  226. package/driver/mysql/MysqlQueryRunner.js +219 -24
  227. package/driver/mysql/MysqlQueryRunner.js.map +1 -1
  228. package/driver/oracle/OracleDriver.js +79 -15
  229. package/driver/oracle/OracleDriver.js.map +1 -1
  230. package/driver/oracle/OracleQueryRunner.d.ts +3 -3
  231. package/driver/oracle/OracleQueryRunner.js +216 -42
  232. package/driver/oracle/OracleQueryRunner.js.map +1 -1
  233. package/driver/postgres/PostgresDriver.js +95 -18
  234. package/driver/postgres/PostgresDriver.js.map +1 -1
  235. package/driver/postgres/PostgresQueryRunner.d.ts +3 -3
  236. package/driver/postgres/PostgresQueryRunner.js +159 -59
  237. package/driver/postgres/PostgresQueryRunner.js.map +1 -1
  238. package/driver/spanner/SpannerConnectionCredentialsOptions.d.ts +17 -0
  239. package/driver/spanner/SpannerConnectionCredentialsOptions.js +4 -0
  240. package/driver/spanner/SpannerConnectionCredentialsOptions.js.map +1 -0
  241. package/driver/spanner/SpannerConnectionOptions.d.ts +120 -0
  242. package/driver/spanner/SpannerConnectionOptions.js +4 -0
  243. package/driver/spanner/SpannerConnectionOptions.js.map +1 -0
  244. package/driver/spanner/SpannerDriver.d.ts +241 -0
  245. package/driver/spanner/SpannerDriver.js +608 -0
  246. package/driver/spanner/SpannerDriver.js.map +1 -0
  247. package/driver/spanner/SpannerQueryRunner.d.ts +350 -0
  248. package/driver/spanner/SpannerQueryRunner.js +1449 -0
  249. package/driver/spanner/SpannerQueryRunner.js.map +1 -0
  250. package/driver/sqlite-abstract/AbstractSqliteDriver.js +65 -16
  251. package/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  252. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +218 -32
  253. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  254. package/driver/sqlserver/SqlServerDriver.d.ts +3 -1
  255. package/driver/sqlserver/SqlServerDriver.js +99 -26
  256. package/driver/sqlserver/SqlServerDriver.js.map +1 -1
  257. package/driver/sqlserver/SqlServerQueryRunner.d.ts +3 -3
  258. package/driver/sqlserver/SqlServerQueryRunner.js +251 -37
  259. package/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  260. package/driver/sqlserver/authentication/AzureActiveDirectoryAccessTokenAuthentication.d.ts +1 -1
  261. package/driver/sqlserver/authentication/AzureActiveDirectoryAccessTokenAuthentication.js.map +1 -1
  262. package/driver/sqlserver/authentication/AzureActiveDirectoryMsiAppServiceAuthentication.d.ts +2 -2
  263. package/driver/sqlserver/authentication/AzureActiveDirectoryMsiAppServiceAuthentication.js.map +1 -1
  264. package/driver/sqlserver/authentication/AzureActiveDirectoryMsiVmAuthentication.d.ts +2 -2
  265. package/driver/sqlserver/authentication/AzureActiveDirectoryMsiVmAuthentication.js.map +1 -1
  266. package/driver/sqlserver/authentication/AzureActiveDirectoryPasswordAuthentication.d.ts +2 -2
  267. package/driver/sqlserver/authentication/AzureActiveDirectoryPasswordAuthentication.js.map +1 -1
  268. package/driver/types/ColumnTypes.d.ts +1 -1
  269. package/driver/types/ColumnTypes.js.map +1 -1
  270. package/driver/types/DatabaseType.d.ts +1 -1
  271. package/driver/types/DatabaseType.js.map +1 -1
  272. package/entity-manager/EntityManager.js +1 -1
  273. package/entity-manager/EntityManager.js.map +1 -1
  274. package/entity-schema/EntitySchemaColumnOptions.d.ts +6 -2
  275. package/entity-schema/EntitySchemaColumnOptions.js.map +1 -1
  276. package/entity-schema/EntitySchemaIndexOptions.d.ts +8 -0
  277. package/entity-schema/EntitySchemaIndexOptions.js.map +1 -1
  278. package/entity-schema/EntitySchemaTransformer.js +3 -0
  279. package/entity-schema/EntitySchemaTransformer.js.map +1 -1
  280. package/find-options/FindOneOptions.d.ts +1 -1
  281. package/find-options/FindOneOptions.js.map +1 -1
  282. package/find-options/FindOptionsUtils.d.ts +2 -1
  283. package/find-options/FindOptionsUtils.js +2 -1
  284. package/find-options/FindOptionsUtils.js.map +1 -1
  285. package/logger/AdvancedConsoleLogger.d.ts +1 -1
  286. package/logger/AdvancedConsoleLogger.js +1 -1
  287. package/logger/AdvancedConsoleLogger.js.map +1 -1
  288. package/metadata/ColumnMetadata.d.ts +10 -2
  289. package/metadata/ColumnMetadata.js +8 -0
  290. package/metadata/ColumnMetadata.js.map +1 -1
  291. package/metadata/EntityMetadata.js +1 -1
  292. package/metadata/EntityMetadata.js.map +1 -1
  293. package/metadata/ForeignKeyMetadata.d.ts +7 -0
  294. package/metadata/ForeignKeyMetadata.js +4 -1
  295. package/metadata/ForeignKeyMetadata.js.map +1 -1
  296. package/metadata/IndexMetadata.d.ts +8 -0
  297. package/metadata/IndexMetadata.js +9 -0
  298. package/metadata/IndexMetadata.js.map +1 -1
  299. package/metadata-args/IndexMetadataArgs.d.ts +8 -0
  300. package/metadata-args/IndexMetadataArgs.js.map +1 -1
  301. package/metadata-args/JoinColumnMetadataArgs.d.ts +4 -0
  302. package/metadata-args/JoinColumnMetadataArgs.js.map +1 -1
  303. package/metadata-builder/EntityMetadataBuilder.js +13 -6
  304. package/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  305. package/metadata-builder/EntityMetadataValidator.js +17 -0
  306. package/metadata-builder/EntityMetadataValidator.js.map +1 -1
  307. package/metadata-builder/JunctionEntityMetadataBuilder.js +18 -6
  308. package/metadata-builder/JunctionEntityMetadataBuilder.js.map +1 -1
  309. package/metadata-builder/RelationJoinColumnBuilder.js +2 -0
  310. package/metadata-builder/RelationJoinColumnBuilder.js.map +1 -1
  311. package/migration/MigrationExecutor.js +1 -1
  312. package/migration/MigrationExecutor.js.map +1 -1
  313. package/package.json +1 -1
  314. package/persistence/SubjectDatabaseEntityLoader.d.ts +1 -1
  315. package/persistence/SubjectDatabaseEntityLoader.js +1 -1
  316. package/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
  317. package/persistence/SubjectExecutor.js +1 -1
  318. package/persistence/SubjectExecutor.js.map +1 -1
  319. package/persistence/subject-builder/CascadesSubjectBuilder.d.ts +1 -1
  320. package/persistence/subject-builder/CascadesSubjectBuilder.js +1 -1
  321. package/persistence/subject-builder/CascadesSubjectBuilder.js.map +1 -1
  322. package/persistence/subject-builder/ManyToManySubjectBuilder.js +1 -1
  323. package/persistence/subject-builder/ManyToManySubjectBuilder.js.map +1 -1
  324. package/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js +1 -1
  325. package/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js.map +1 -1
  326. package/platform/PlatformTools.js +5 -0
  327. package/platform/PlatformTools.js.map +1 -1
  328. package/query-builder/InsertQueryBuilder.js +15 -3
  329. package/query-builder/InsertQueryBuilder.js.map +1 -1
  330. package/query-builder/QueryBuilder.d.ts +1 -1
  331. package/query-builder/QueryBuilder.js +15 -15
  332. package/query-builder/QueryBuilder.js.map +1 -1
  333. package/query-builder/QueryExpressionMap.d.ts +2 -2
  334. package/query-builder/QueryExpressionMap.js +1 -1
  335. package/query-builder/QueryExpressionMap.js.map +1 -1
  336. package/query-builder/ReturningResultsEntityUpdator.js +2 -2
  337. package/query-builder/ReturningResultsEntityUpdator.js.map +1 -1
  338. package/query-builder/SelectQueryBuilder.d.ts +1 -1
  339. package/query-builder/SelectQueryBuilder.js +25 -4
  340. package/query-builder/SelectQueryBuilder.js.map +1 -1
  341. package/query-builder/UpdateQueryBuilder.js +18 -7
  342. package/query-builder/UpdateQueryBuilder.js.map +1 -1
  343. package/query-runner/BaseQueryRunner.d.ts +10 -0
  344. package/query-runner/BaseQueryRunner.js +25 -1
  345. package/query-runner/BaseQueryRunner.js.map +1 -1
  346. package/query-runner/QueryRunner.d.ts +2 -2
  347. package/query-runner/QueryRunner.js.map +1 -1
  348. package/schema-builder/RdbmsSchemaBuilder.d.ts +6 -2
  349. package/schema-builder/RdbmsSchemaBuilder.js +26 -6
  350. package/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  351. package/schema-builder/options/TableColumnOptions.d.ts +10 -2
  352. package/schema-builder/options/TableColumnOptions.js.map +1 -1
  353. package/schema-builder/options/TableForeignKeyOptions.d.ts +1 -1
  354. package/schema-builder/options/TableForeignKeyOptions.js.map +1 -1
  355. package/schema-builder/options/TableIndexOptions.d.ts +8 -0
  356. package/schema-builder/options/TableIndexOptions.js.map +1 -1
  357. package/schema-builder/table/TableColumn.d.ts +6 -2
  358. package/schema-builder/table/TableColumn.js +2 -0
  359. package/schema-builder/table/TableColumn.js.map +1 -1
  360. package/schema-builder/table/TableIndex.d.ts +8 -0
  361. package/schema-builder/table/TableIndex.js +3 -0
  362. package/schema-builder/table/TableIndex.js.map +1 -1
  363. package/schema-builder/util/TableUtils.js +1 -0
  364. package/schema-builder/util/TableUtils.js.map +1 -1
  365. package/util/OrmUtils.d.ts +1 -1
  366. package/util/OrmUtils.js +4 -4
  367. package/util/OrmUtils.js.map +1 -1
  368. package/util/escapeRegExp.d.ts +1 -0
  369. package/util/escapeRegExp.js +10 -0
  370. package/util/escapeRegExp.js.map +1 -0
@@ -0,0 +1,604 @@
1
+ import { DriverPackageNotInstalledError } from "../../error/DriverPackageNotInstalledError";
2
+ import { SpannerQueryRunner } from "./SpannerQueryRunner";
3
+ import { DateUtils } from "../../util/DateUtils";
4
+ import { PlatformTools } from "../../platform/PlatformTools";
5
+ import { RdbmsSchemaBuilder } from "../../schema-builder/RdbmsSchemaBuilder";
6
+ import { EntityMetadata } from "../../metadata/EntityMetadata";
7
+ import { OrmUtils } from "../../util/OrmUtils";
8
+ import { ApplyValueTransformers } from "../../util/ApplyValueTransformers";
9
+ import { Table } from "../../schema-builder/table/Table";
10
+ import { View } from "../../schema-builder/view/View";
11
+ import { TableForeignKey } from "../../schema-builder/table/TableForeignKey";
12
+ /**
13
+ * Organizes communication with Spanner DBMS.
14
+ */
15
+ export class SpannerDriver {
16
+ // -------------------------------------------------------------------------
17
+ // Constructor
18
+ // -------------------------------------------------------------------------
19
+ constructor(connection) {
20
+ /**
21
+ * Indicates if replication is enabled.
22
+ */
23
+ this.isReplicated = false;
24
+ /**
25
+ * Indicates if tree tables are supported by this driver.
26
+ */
27
+ this.treeSupport = true;
28
+ /**
29
+ * Represent transaction support by this driver
30
+ */
31
+ this.transactionSupport = "none";
32
+ /**
33
+ * Gets list of supported column data types by a driver.
34
+ *
35
+ * @see https://cloud.google.com/spanner/docs/reference/standard-sql/data-types
36
+ */
37
+ this.supportedDataTypes = [
38
+ "bool",
39
+ "int64",
40
+ "float64",
41
+ "numeric",
42
+ "string",
43
+ "json",
44
+ "bytes",
45
+ "date",
46
+ "timestamp",
47
+ "array",
48
+ ];
49
+ /**
50
+ * Returns type of upsert supported by driver if any
51
+ */
52
+ this.supportedUpsertType = undefined;
53
+ /**
54
+ * Gets list of spatial column data types.
55
+ */
56
+ this.spatialTypes = [];
57
+ /**
58
+ * Gets list of column data types that support length by a driver.
59
+ */
60
+ this.withLengthColumnTypes = ["string", "bytes"];
61
+ /**
62
+ * Gets list of column data types that support length by a driver.
63
+ */
64
+ this.withWidthColumnTypes = [];
65
+ /**
66
+ * Gets list of column data types that support precision by a driver.
67
+ */
68
+ this.withPrecisionColumnTypes = [];
69
+ /**
70
+ * Gets list of column data types that supports scale by a driver.
71
+ */
72
+ this.withScaleColumnTypes = [];
73
+ /**
74
+ * ORM has special columns and we need to know what database column types should be for those columns.
75
+ * Column types are driver dependant.
76
+ */
77
+ this.mappedDataTypes = {
78
+ createDate: "timestamp",
79
+ createDateDefault: "",
80
+ updateDate: "timestamp",
81
+ updateDateDefault: "",
82
+ deleteDate: "timestamp",
83
+ deleteDateNullable: true,
84
+ version: "int64",
85
+ treeLevel: "int64",
86
+ migrationId: "int64",
87
+ migrationName: "string",
88
+ migrationTimestamp: "int64",
89
+ cacheId: "string",
90
+ cacheIdentifier: "string",
91
+ cacheTime: "int64",
92
+ cacheDuration: "int64",
93
+ cacheQuery: "string",
94
+ cacheResult: "string",
95
+ metadataType: "string",
96
+ metadataDatabase: "string",
97
+ metadataSchema: "string",
98
+ metadataTable: "string",
99
+ metadataName: "string",
100
+ metadataValue: "string",
101
+ };
102
+ /**
103
+ * Default values of length, precision and scale depends on column data type.
104
+ * Used in the cases when length/precision/scale is not specified by user.
105
+ */
106
+ this.dataTypeDefaults = {};
107
+ /**
108
+ * Max length allowed by MySQL for aliases.
109
+ * @see https://dev.mysql.com/doc/refman/5.5/en/identifiers.html
110
+ */
111
+ this.maxAliasLength = 63;
112
+ this.cteCapabilities = {
113
+ enabled: true,
114
+ };
115
+ /**
116
+ * Supported returning types
117
+ */
118
+ this._isReturningSqlSupported = {
119
+ delete: false,
120
+ insert: false,
121
+ update: false,
122
+ };
123
+ this.connection = connection;
124
+ this.options = connection.options;
125
+ this.isReplicated = this.options.replication ? true : false;
126
+ // load mysql package
127
+ this.loadDependencies();
128
+ }
129
+ // -------------------------------------------------------------------------
130
+ // Public Methods
131
+ // -------------------------------------------------------------------------
132
+ /**
133
+ * Performs connection to the database.
134
+ */
135
+ async connect() {
136
+ this.instance = this.spanner.instance(this.options.instanceId);
137
+ this.instanceDatabase = this.instance.database(this.options.databaseId);
138
+ }
139
+ /**
140
+ * Makes any action after connection (e.g. create extensions in Postgres driver).
141
+ */
142
+ afterConnect() {
143
+ return Promise.resolve();
144
+ }
145
+ /**
146
+ * Closes connection with the database.
147
+ */
148
+ async disconnect() {
149
+ this.instanceDatabase.close();
150
+ }
151
+ /**
152
+ * Creates a schema builder used to build and sync a schema.
153
+ */
154
+ createSchemaBuilder() {
155
+ return new RdbmsSchemaBuilder(this.connection);
156
+ }
157
+ /**
158
+ * Creates a query runner used to execute database queries.
159
+ */
160
+ createQueryRunner(mode) {
161
+ return new SpannerQueryRunner(this, mode);
162
+ }
163
+ /**
164
+ * Replaces parameters in the given sql with special escaping character
165
+ * and an array of parameter names to be passed to a query.
166
+ */
167
+ escapeQueryWithParameters(sql, parameters, nativeParameters) {
168
+ const escapedParameters = Object.keys(nativeParameters).map((key) => nativeParameters[key]);
169
+ if (!parameters || !Object.keys(parameters).length)
170
+ return [sql, escapedParameters];
171
+ sql = sql.replace(/:(\.\.\.)?([A-Za-z0-9_.]+)/g, (full, isArray, key) => {
172
+ if (!parameters.hasOwnProperty(key)) {
173
+ return full;
174
+ }
175
+ let value = parameters[key];
176
+ if (value === null) {
177
+ return full;
178
+ }
179
+ if (isArray) {
180
+ return value
181
+ .map((v) => {
182
+ escapedParameters.push(v);
183
+ return this.createParameter(key, escapedParameters.length - 1);
184
+ })
185
+ .join(", ");
186
+ }
187
+ if (value instanceof Function) {
188
+ return value();
189
+ }
190
+ escapedParameters.push(value);
191
+ return this.createParameter(key, escapedParameters.length - 1);
192
+ }); // todo: make replace only in value statements, otherwise problems
193
+ sql = sql.replace(/([ ]+)?=([ ]+)?:(\.\.\.)?([A-Za-z0-9_.]+)/g, (full, emptySpaceBefore, emptySpaceAfter, isArray, key) => {
194
+ if (!parameters.hasOwnProperty(key)) {
195
+ return full;
196
+ }
197
+ let value = parameters[key];
198
+ if (value === null) {
199
+ return " IS NULL";
200
+ }
201
+ return full;
202
+ });
203
+ return [sql, escapedParameters];
204
+ }
205
+ /**
206
+ * Escapes a column name.
207
+ */
208
+ escape(columnName) {
209
+ return `\`${columnName}\``;
210
+ }
211
+ /**
212
+ * Build full table name with database name, schema name and table name.
213
+ * E.g. myDB.mySchema.myTable
214
+ */
215
+ buildTableName(tableName, schema, database) {
216
+ let tablePath = [tableName];
217
+ if (database) {
218
+ tablePath.unshift(database);
219
+ }
220
+ return tablePath.join(".");
221
+ }
222
+ /**
223
+ * Parse a target table name or other types and return a normalized table definition.
224
+ */
225
+ parseTableName(target) {
226
+ const driverDatabase = this.database;
227
+ const driverSchema = undefined;
228
+ if (target instanceof Table || target instanceof View) {
229
+ const parsed = this.parseTableName(target.name);
230
+ return {
231
+ database: target.database || parsed.database || driverDatabase,
232
+ schema: target.schema || parsed.schema || driverSchema,
233
+ tableName: parsed.tableName,
234
+ };
235
+ }
236
+ if (target instanceof TableForeignKey) {
237
+ const parsed = this.parseTableName(target.referencedTableName);
238
+ return {
239
+ database: target.referencedDatabase ||
240
+ parsed.database ||
241
+ driverDatabase,
242
+ schema: target.referencedSchema || parsed.schema || driverSchema,
243
+ tableName: parsed.tableName,
244
+ };
245
+ }
246
+ if (target instanceof EntityMetadata) {
247
+ // EntityMetadata tableName is never a path
248
+ return {
249
+ database: target.database || driverDatabase,
250
+ schema: target.schema || driverSchema,
251
+ tableName: target.tableName,
252
+ };
253
+ }
254
+ const parts = target.split(".");
255
+ return {
256
+ database: (parts.length > 1 ? parts[0] : undefined) || driverDatabase,
257
+ schema: driverSchema,
258
+ tableName: parts.length > 1 ? parts[1] : parts[0],
259
+ };
260
+ }
261
+ /**
262
+ * Prepares given value to a value to be persisted, based on its column type and metadata.
263
+ */
264
+ preparePersistentValue(value, columnMetadata) {
265
+ if (columnMetadata.transformer)
266
+ value = ApplyValueTransformers.transformTo(columnMetadata.transformer, value);
267
+ if (value === null || value === undefined)
268
+ return value;
269
+ if (columnMetadata.type === "numeric") {
270
+ const lib = this.options.driver || PlatformTools.load("spanner");
271
+ return lib.Spanner.numeric(value);
272
+ }
273
+ else if (columnMetadata.type === "date") {
274
+ return DateUtils.mixedDateToDateString(value);
275
+ }
276
+ else if (columnMetadata.type === "json") {
277
+ return value;
278
+ }
279
+ else if (columnMetadata.type === "timestamp" ||
280
+ columnMetadata.type === Date) {
281
+ return DateUtils.mixedDateToDate(value);
282
+ }
283
+ return value;
284
+ }
285
+ /**
286
+ * Prepares given value to a value to be persisted, based on its column type or metadata.
287
+ */
288
+ prepareHydratedValue(value, columnMetadata) {
289
+ if (value === null || value === undefined)
290
+ return columnMetadata.transformer
291
+ ? ApplyValueTransformers.transformFrom(columnMetadata.transformer, value)
292
+ : value;
293
+ if (columnMetadata.type === Boolean || columnMetadata.type === "bool") {
294
+ value = value ? true : false;
295
+ }
296
+ else if (columnMetadata.type === "timestamp" ||
297
+ columnMetadata.type === Date) {
298
+ value = new Date(value);
299
+ }
300
+ else if (columnMetadata.type === "numeric") {
301
+ value = value.value;
302
+ }
303
+ else if (columnMetadata.type === "date") {
304
+ value = DateUtils.mixedDateToDateString(value);
305
+ }
306
+ else if (columnMetadata.type === "json") {
307
+ value = typeof value === "string" ? JSON.parse(value) : value;
308
+ }
309
+ if (columnMetadata.transformer)
310
+ value = ApplyValueTransformers.transformFrom(columnMetadata.transformer, value);
311
+ return value;
312
+ }
313
+ /**
314
+ * Creates a database type from a given column metadata.
315
+ */
316
+ normalizeType(column) {
317
+ if (column.type === Number) {
318
+ return "int64";
319
+ }
320
+ else if (column.type === String || column.type === "uuid") {
321
+ return "string";
322
+ }
323
+ else if (column.type === Date) {
324
+ return "timestamp";
325
+ }
326
+ else if (column.type === Buffer) {
327
+ return "bytes";
328
+ }
329
+ else if (column.type === Boolean) {
330
+ return "bool";
331
+ }
332
+ else {
333
+ return column.type || "";
334
+ }
335
+ }
336
+ /**
337
+ * Normalizes "default" value of the column.
338
+ *
339
+ * Spanner does not support default values.
340
+ */
341
+ normalizeDefault(columnMetadata) {
342
+ return columnMetadata.default === ""
343
+ ? `"${columnMetadata.default}"`
344
+ : `${columnMetadata.default}`;
345
+ }
346
+ /**
347
+ * Normalizes "isUnique" value of the column.
348
+ */
349
+ normalizeIsUnique(column) {
350
+ return column.entityMetadata.indices.some((idx) => idx.isUnique &&
351
+ idx.columns.length === 1 &&
352
+ idx.columns[0] === column);
353
+ }
354
+ /**
355
+ * Returns default column lengths, which is required on column creation.
356
+ */
357
+ getColumnLength(column) {
358
+ if (column.length)
359
+ return column.length.toString();
360
+ if (column.generationStrategy === "uuid")
361
+ return "36";
362
+ switch (column.type) {
363
+ case String:
364
+ case "string":
365
+ case "bytes":
366
+ return "max";
367
+ default:
368
+ return "";
369
+ }
370
+ }
371
+ /**
372
+ * Creates column type definition including length, precision and scale
373
+ */
374
+ createFullType(column) {
375
+ let type = column.type;
376
+ // used 'getColumnLength()' method, because Spanner requires column length for `string` and `bytes` data types
377
+ if (this.getColumnLength(column)) {
378
+ type += `(${this.getColumnLength(column)})`;
379
+ }
380
+ else if (column.width) {
381
+ type += `(${column.width})`;
382
+ }
383
+ else if (column.precision !== null &&
384
+ column.precision !== undefined &&
385
+ column.scale !== null &&
386
+ column.scale !== undefined) {
387
+ type += `(${column.precision},${column.scale})`;
388
+ }
389
+ else if (column.precision !== null &&
390
+ column.precision !== undefined) {
391
+ type += `(${column.precision})`;
392
+ }
393
+ if (column.isArray)
394
+ type = `array<${type}>`;
395
+ return type;
396
+ }
397
+ /**
398
+ * Obtains a new database connection to a master server.
399
+ * Used for replication.
400
+ * If replication is not setup then returns default connection's database connection.
401
+ */
402
+ obtainMasterConnection() {
403
+ return this.instanceDatabase;
404
+ }
405
+ /**
406
+ * Obtains a new database connection to a slave server.
407
+ * Used for replication.
408
+ * If replication is not setup then returns master (default) connection's database connection.
409
+ */
410
+ obtainSlaveConnection() {
411
+ return this.instanceDatabase;
412
+ }
413
+ /**
414
+ * Creates generated map of values generated or returned by database after INSERT query.
415
+ */
416
+ createGeneratedMap(metadata, insertResult, entityIndex) {
417
+ if (!insertResult) {
418
+ return undefined;
419
+ }
420
+ if (insertResult.insertId === undefined) {
421
+ return Object.keys(insertResult).reduce((map, key) => {
422
+ const column = metadata.findColumnWithDatabaseName(key);
423
+ if (column) {
424
+ OrmUtils.mergeDeep(map, column.createValueMap(insertResult[key]));
425
+ // OrmUtils.mergeDeep(map, column.createValueMap(this.prepareHydratedValue(insertResult[key], column))); // TODO: probably should be like there, but fails on enums, fix later
426
+ }
427
+ return map;
428
+ }, {});
429
+ }
430
+ const generatedMap = metadata.generatedColumns.reduce((map, generatedColumn) => {
431
+ let value;
432
+ if (generatedColumn.generationStrategy === "increment" &&
433
+ insertResult.insertId) {
434
+ // NOTE: When multiple rows is inserted by a single INSERT statement,
435
+ // `insertId` is the value generated for the first inserted row only.
436
+ value = insertResult.insertId + entityIndex;
437
+ // } else if (generatedColumn.generationStrategy === "uuid") {
438
+ // console.log("getting db value:", generatedColumn.databaseName);
439
+ // value = generatedColumn.getEntityValue(uuidMap);
440
+ }
441
+ return OrmUtils.mergeDeep(map, generatedColumn.createValueMap(value));
442
+ }, {});
443
+ return Object.keys(generatedMap).length > 0 ? generatedMap : undefined;
444
+ }
445
+ /**
446
+ * Differentiate columns of this table and columns from the given column metadatas columns
447
+ * and returns only changed.
448
+ */
449
+ findChangedColumns(tableColumns, columnMetadatas) {
450
+ return columnMetadatas.filter((columnMetadata) => {
451
+ const tableColumn = tableColumns.find((c) => c.name === columnMetadata.databaseName);
452
+ if (!tableColumn)
453
+ return false; // we don't need new columns, we only need exist and changed
454
+ const isColumnChanged = tableColumn.name !== columnMetadata.databaseName ||
455
+ tableColumn.type !== this.normalizeType(columnMetadata) ||
456
+ tableColumn.length !== this.getColumnLength(columnMetadata) ||
457
+ tableColumn.asExpression !== columnMetadata.asExpression ||
458
+ tableColumn.generatedType !== columnMetadata.generatedType ||
459
+ tableColumn.isPrimary !== columnMetadata.isPrimary ||
460
+ !this.compareNullableValues(columnMetadata, tableColumn) ||
461
+ tableColumn.isUnique !== this.normalizeIsUnique(columnMetadata);
462
+ // DEBUG SECTION
463
+ // if (isColumnChanged) {
464
+ // console.log("table:", columnMetadata.entityMetadata.tableName)
465
+ // console.log(
466
+ // "name:",
467
+ // tableColumn.name,
468
+ // columnMetadata.databaseName,
469
+ // )
470
+ // console.log(
471
+ // "type:",
472
+ // tableColumn.type,
473
+ // this.normalizeType(columnMetadata),
474
+ // )
475
+ // console.log(
476
+ // "length:",
477
+ // tableColumn.length,
478
+ // this.getColumnLength(columnMetadata),
479
+ // )
480
+ // console.log(
481
+ // "asExpression:",
482
+ // tableColumn.asExpression,
483
+ // columnMetadata.asExpression,
484
+ // )
485
+ // console.log(
486
+ // "generatedType:",
487
+ // tableColumn.generatedType,
488
+ // columnMetadata.generatedType,
489
+ // )
490
+ // console.log(
491
+ // "isPrimary:",
492
+ // tableColumn.isPrimary,
493
+ // columnMetadata.isPrimary,
494
+ // )
495
+ // console.log(
496
+ // "isNullable:",
497
+ // tableColumn.isNullable,
498
+ // columnMetadata.isNullable,
499
+ // )
500
+ // console.log(
501
+ // "isUnique:",
502
+ // tableColumn.isUnique,
503
+ // this.normalizeIsUnique(columnMetadata),
504
+ // )
505
+ // console.log("==========================================")
506
+ // }
507
+ return isColumnChanged;
508
+ });
509
+ }
510
+ /**
511
+ * Returns true if driver supports RETURNING / OUTPUT statement.
512
+ */
513
+ isReturningSqlSupported(returningType) {
514
+ return this._isReturningSqlSupported[returningType];
515
+ }
516
+ /**
517
+ * Returns true if driver supports uuid values generation on its own.
518
+ */
519
+ isUUIDGenerationSupported() {
520
+ return false;
521
+ }
522
+ /**
523
+ * Returns true if driver supports fulltext indices.
524
+ */
525
+ isFullTextColumnTypeSupported() {
526
+ return false;
527
+ }
528
+ /**
529
+ * Creates an escaped parameter.
530
+ */
531
+ createParameter(parameterName, index) {
532
+ return "@param" + index;
533
+ }
534
+ // -------------------------------------------------------------------------
535
+ // Protected Methods
536
+ // -------------------------------------------------------------------------
537
+ /**
538
+ * Loads all driver dependencies.
539
+ */
540
+ loadDependencies() {
541
+ try {
542
+ const lib = this.options.driver || PlatformTools.load("spanner");
543
+ this.spanner = new lib.Spanner({
544
+ projectId: this.options.projectId,
545
+ });
546
+ }
547
+ catch (e) {
548
+ console.error(e);
549
+ throw new DriverPackageNotInstalledError("Spanner", "@google-cloud/spanner");
550
+ }
551
+ }
552
+ compareNullableValues(columnMetadata, tableColumn) {
553
+ // Spanner does not support NULL/NOT NULL expressions for generated columns
554
+ if (columnMetadata.generatedType) {
555
+ return true;
556
+ }
557
+ return columnMetadata.isNullable === tableColumn.isNullable;
558
+ }
559
+ /**
560
+ * Checks if "DEFAULT" values in the column metadata and in the database are equal.
561
+ */
562
+ compareDefaultValues(columnMetadataValue, databaseValue) {
563
+ if (typeof columnMetadataValue === "string" &&
564
+ typeof databaseValue === "string") {
565
+ // we need to cut out "'" because in mysql we can understand returned value is a string or a function
566
+ // as result compare cannot understand if default is really changed or not
567
+ columnMetadataValue = columnMetadataValue.replace(/^'+|'+$/g, "");
568
+ databaseValue = databaseValue.replace(/^'+|'+$/g, "");
569
+ }
570
+ return columnMetadataValue === databaseValue;
571
+ }
572
+ /**
573
+ * If parameter is a datetime function, e.g. "CURRENT_TIMESTAMP", normalizes it.
574
+ * Otherwise returns original input.
575
+ */
576
+ normalizeDatetimeFunction(value) {
577
+ if (!value)
578
+ return value;
579
+ // check if input is datetime function
580
+ const isDatetimeFunction = value.toUpperCase().indexOf("CURRENT_TIMESTAMP") !== -1 ||
581
+ value.toUpperCase().indexOf("NOW") !== -1;
582
+ if (isDatetimeFunction) {
583
+ // extract precision, e.g. "(3)"
584
+ const precision = value.match(/\(\d+\)/);
585
+ return precision
586
+ ? `CURRENT_TIMESTAMP${precision[0]}`
587
+ : "CURRENT_TIMESTAMP";
588
+ }
589
+ else {
590
+ return value;
591
+ }
592
+ }
593
+ /**
594
+ * Escapes a given comment.
595
+ */
596
+ escapeComment(comment) {
597
+ if (!comment)
598
+ return comment;
599
+ comment = comment.replace(/\u0000/g, ""); // Null bytes aren't allowed in comments
600
+ return comment;
601
+ }
602
+ }
603
+
604
+ //# sourceMappingURL=SpannerDriver.js.map