effect-qb 0.17.0 → 0.19.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +4 -0
- package/dist/index.js +8065 -0
- package/dist/mysql.js +3053 -2505
- package/dist/postgres/metadata.js +1366 -1250
- package/dist/postgres.js +2020 -2719
- package/dist/sqlite.js +3226 -2732
- package/dist/standard.js +8019 -0
- package/package.json +10 -3
- package/src/casing.ts +71 -0
- package/src/index.ts +2 -0
- package/src/internal/casing.ts +89 -0
- package/src/internal/column-state.ts +11 -6
- package/src/internal/column.ts +44 -7
- package/src/internal/datatypes/define.ts +2 -1
- package/src/internal/datatypes/enrich.ts +23 -0
- package/src/internal/datatypes/lookup.ts +14 -7
- package/src/internal/derived-table.ts +4 -36
- package/src/{mysql/internal/sql-expression-renderer.ts → internal/dialect-renderers/mysql.ts} +548 -359
- package/src/{postgres/internal/sql-expression-renderer.ts → internal/dialect-renderers/postgres.ts} +654 -399
- package/src/{sqlite/internal/sql-expression-renderer.ts → internal/dialect-renderers/sqlite.ts} +501 -345
- package/src/internal/dialect.ts +35 -0
- package/src/internal/dsl-mutation-runtime.ts +12 -162
- package/src/internal/dsl-plan-runtime.ts +10 -138
- package/src/internal/dsl-query-runtime.ts +5 -79
- package/src/internal/dsl-transaction-ddl-runtime.ts +41 -65
- package/src/internal/executor.ts +10 -6
- package/src/internal/grouping-key.ts +87 -20
- package/src/internal/implication-runtime.ts +1 -1
- package/src/internal/predicate/runtime.ts +3 -0
- package/src/internal/query.d.ts +38 -11
- package/src/internal/query.ts +64 -25
- package/src/internal/renderer.ts +26 -14
- package/src/internal/runtime/normalize.ts +12 -5
- package/src/internal/scalar.ts +6 -1
- package/src/internal/schema-derivation.d.ts +12 -61
- package/src/internal/schema-derivation.ts +90 -38
- package/src/internal/schema-expression.ts +2 -2
- package/src/internal/sql-expression-renderer.ts +19 -0
- package/src/internal/standard-dsl.ts +6885 -0
- package/src/internal/table-options.ts +126 -66
- package/src/internal/table.d.ts +33 -32
- package/src/internal/table.ts +406 -155
- package/src/mysql/column-extension.ts +3 -0
- package/src/mysql/column.ts +10 -11
- package/src/mysql/datatypes/index.ts +3 -2
- package/src/mysql/executor.ts +7 -5
- package/src/mysql/internal/dialect.ts +9 -4
- package/src/mysql/internal/dsl.ts +219 -155
- package/src/mysql/internal/renderer.ts +6 -2
- package/src/mysql/json.ts +37 -0
- package/src/mysql/query-extension.ts +16 -0
- package/src/mysql/renderer.ts +31 -4
- package/src/mysql.ts +4 -12
- package/src/postgres/column-extension.ts +28 -0
- package/src/postgres/column.ts +5 -11
- package/src/postgres/datatypes/index.d.ts +2 -1
- package/src/postgres/datatypes/index.ts +3 -2
- package/src/postgres/executor.ts +7 -5
- package/src/postgres/function/core.ts +1 -3
- package/src/postgres/function/index.ts +1 -17
- package/src/postgres/internal/dialect.ts +9 -4
- package/src/postgres/internal/dsl.ts +208 -160
- package/src/postgres/internal/renderer.ts +6 -2
- package/src/postgres/internal/schema-ddl.ts +22 -10
- package/src/postgres/internal/schema-model.ts +238 -7
- package/src/postgres/json.ts +43 -7
- package/src/postgres/jsonb.ts +38 -0
- package/src/postgres/query-extension.ts +2 -0
- package/src/postgres/renderer.ts +31 -4
- package/src/postgres/schema-management.ts +17 -12
- package/src/postgres/schema.ts +98 -15
- package/src/postgres/table.ts +193 -524
- package/src/postgres/type.ts +8 -7
- package/src/postgres.ts +9 -11
- package/src/sqlite/column-extension.ts +3 -0
- package/src/sqlite/column.ts +10 -11
- package/src/sqlite/datatypes/index.ts +3 -2
- package/src/sqlite/executor.ts +7 -5
- package/src/sqlite/internal/dialect.ts +9 -4
- package/src/sqlite/internal/dsl.ts +208 -155
- package/src/sqlite/internal/renderer.ts +6 -2
- package/src/sqlite/json.ts +37 -0
- package/src/sqlite/query-extension.ts +2 -0
- package/src/sqlite/renderer.ts +31 -4
- package/src/sqlite.ts +4 -12
- package/src/standard/column.ts +163 -0
- package/src/standard/datatypes/index.ts +83 -0
- package/src/standard/datatypes/spec.ts +98 -0
- package/src/standard/dialect.ts +40 -0
- package/src/standard/function/aggregate.ts +2 -0
- package/src/standard/function/core.ts +2 -0
- package/src/standard/function/index.ts +18 -0
- package/src/standard/function/string.ts +2 -0
- package/src/standard/function/temporal.ts +78 -0
- package/src/standard/function/window.ts +2 -0
- package/src/standard/internal/renderer.ts +45 -0
- package/src/standard/query.ts +152 -0
- package/src/standard/renderer.ts +21 -0
- package/src/standard/table.ts +147 -0
- package/src/standard.ts +18 -0
- package/src/internal/aggregation-validation.ts +0 -57
- package/src/mysql/table.ts +0 -183
- package/src/sqlite/table.ts +0 -183
package/src/mysql/column.ts
CHANGED
|
@@ -3,6 +3,8 @@ import * as Schema from "effect/Schema"
|
|
|
3
3
|
import * as BaseColumn from "../internal/column.js"
|
|
4
4
|
import { makeColumnDefinition, type AnyColumnDefinition, type ColumnDefinition } from "../internal/column-state.js"
|
|
5
5
|
import type * as Expression from "../internal/scalar.js"
|
|
6
|
+
import type { NonEmptyStringInput } from "../internal/table-options.js"
|
|
7
|
+
import { enrichDbType } from "../internal/datatypes/enrich.js"
|
|
6
8
|
import {
|
|
7
9
|
DecimalStringSchema,
|
|
8
10
|
LocalDateStringSchema,
|
|
@@ -13,13 +15,6 @@ import {
|
|
|
13
15
|
} from "../internal/runtime/value.js"
|
|
14
16
|
import { mysqlDatatypes } from "./datatypes/index.js"
|
|
15
17
|
|
|
16
|
-
const enrichDbType = <Db extends Expression.DbType.Any>(dbType: Db): Db => {
|
|
17
|
-
const candidate = (mysqlDatatypes as unknown as Record<string, (() => Expression.DbType.Any) | undefined>)[dbType.kind]
|
|
18
|
-
return typeof candidate === "function"
|
|
19
|
-
? { ...candidate(), ...dbType } as Db
|
|
20
|
-
: dbType
|
|
21
|
-
}
|
|
22
|
-
|
|
23
18
|
const primitive = <Type, Db extends Expression.DbType.Any>(
|
|
24
19
|
schema: Schema.Schema<Type, any, any>,
|
|
25
20
|
dbType: Db
|
|
@@ -50,8 +45,8 @@ export const custom = <SchemaType extends Schema.Schema.Any, Db extends Expressi
|
|
|
50
45
|
schema: SchemaType,
|
|
51
46
|
dbType: Db
|
|
52
47
|
) =>
|
|
53
|
-
makeColumnDefinition(schema as
|
|
54
|
-
dbType: enrichDbType(dbType),
|
|
48
|
+
makeColumnDefinition(schema as Schema.Schema<NonNullable<Schema.Schema.Type<SchemaType>>, any, any>, {
|
|
49
|
+
dbType: enrichDbType(mysqlDatatypes, dbType),
|
|
55
50
|
nullable: false,
|
|
56
51
|
hasDefault: false,
|
|
57
52
|
generated: false,
|
|
@@ -82,7 +77,7 @@ export const date = () => primitive(LocalDateStringSchema, mysqlDatatypes.date()
|
|
|
82
77
|
export const datetime = () => primitive(LocalDateTimeStringSchema, mysqlDatatypes.datetime())
|
|
83
78
|
export const timestamp = () => primitive(LocalDateTimeStringSchema, mysqlDatatypes.timestamp())
|
|
84
79
|
export const json = <SchemaType extends Schema.Schema.Any>(schema: SchemaType) =>
|
|
85
|
-
makeColumnDefinition(schema as
|
|
80
|
+
makeColumnDefinition(schema as Schema.Schema<NonNullable<Schema.Schema.Type<SchemaType>>, any, any>, {
|
|
86
81
|
dbType: { ...mysqlDatatypes.json(), variant: "json" } as Expression.DbType.Json<"mysql", "json">,
|
|
87
82
|
nullable: false,
|
|
88
83
|
hasDefault: false,
|
|
@@ -106,10 +101,14 @@ type MysqlUniqueOptions = {
|
|
|
106
101
|
readonly initiallyDeferred?: never
|
|
107
102
|
}
|
|
108
103
|
|
|
104
|
+
type NonEmptyOptionNameInput<Options> = Options extends { readonly name: infer Name extends string }
|
|
105
|
+
? NonEmptyStringInput<Name> extends never ? never : unknown
|
|
106
|
+
: unknown
|
|
107
|
+
|
|
109
108
|
type UniqueModifier = {
|
|
110
109
|
<Column extends AnyColumnDefinition>(column: Column): UniqueColumn<Column>
|
|
111
110
|
readonly options: <const Options extends MysqlUniqueOptions>(
|
|
112
|
-
options: Options
|
|
111
|
+
options: Options & NonEmptyOptionNameInput<Options>
|
|
113
112
|
) => <Column extends AnyColumnDefinition>(column: Column) => UniqueColumn<Column>
|
|
114
113
|
}
|
|
115
114
|
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import type { DatatypeModule } from "../../internal/datatypes/define.js"
|
|
2
2
|
import type * as Expression from "../../internal/scalar.js"
|
|
3
|
+
import type { NonEmptyStringInput } from "../../internal/table-options.js"
|
|
3
4
|
import { mysqlDatatypeFamilies, mysqlDatatypeKinds } from "./spec.js"
|
|
4
5
|
|
|
5
6
|
const withMetadata = <Kind extends keyof typeof mysqlDatatypeKinds & string>(
|
|
@@ -19,9 +20,9 @@ const withMetadata = <Kind extends keyof typeof mysqlDatatypeKinds & string>(
|
|
|
19
20
|
}
|
|
20
21
|
|
|
21
22
|
const mysqlDatatypeModule = {
|
|
22
|
-
custom: (kind:
|
|
23
|
+
custom: <Kind extends string>(kind: NonEmptyStringInput<Kind>) => ({
|
|
23
24
|
dialect: "mysql",
|
|
24
|
-
kind
|
|
25
|
+
kind: kind as Kind
|
|
25
26
|
}),
|
|
26
27
|
uuid: () => ({
|
|
27
28
|
dialect: "mysql",
|
package/src/mysql/executor.ts
CHANGED
|
@@ -6,6 +6,7 @@ import * as CoreExecutor from "../internal/executor.js"
|
|
|
6
6
|
import * as CoreQuery from "../internal/query.js"
|
|
7
7
|
import * as CoreRenderer from "../internal/renderer.js"
|
|
8
8
|
import type * as Expression from "../internal/scalar.js"
|
|
9
|
+
import type { MysqlDatatypeFamily, MysqlDatatypeKind } from "./datatypes/spec.js"
|
|
9
10
|
import { renderMysqlPlan } from "./internal/renderer.js"
|
|
10
11
|
import {
|
|
11
12
|
narrowMysqlDriverErrorForReadQuery,
|
|
@@ -24,12 +25,13 @@ export type Driver<Error = never, Context = never> = CoreExecutor.Driver<"mysql"
|
|
|
24
25
|
export type Executor<Error = never, Context = never> = CoreExecutor.Executor<"mysql", Error, Context>
|
|
25
26
|
/** MySQL-specialized renderer contract. */
|
|
26
27
|
export type Renderer = CoreRenderer.Renderer<"mysql">
|
|
28
|
+
export type ValueMappings = Expression.DriverValueMappingsFor<MysqlDatatypeKind | "uuid", MysqlDatatypeFamily | "uuid">
|
|
27
29
|
/** Optional renderer / driver overrides for the standard MySQL executor pipeline. */
|
|
28
30
|
export interface MakeOptions<Error = never, Context = never> {
|
|
29
31
|
readonly renderer?: Renderer
|
|
30
32
|
readonly driver?: Driver<Error, Context>
|
|
31
33
|
readonly driverMode?: CoreExecutor.DriverMode
|
|
32
|
-
readonly valueMappings?:
|
|
34
|
+
readonly valueMappings?: ValueMappings
|
|
33
35
|
}
|
|
34
36
|
/** Standard composed error shape for MySQL executors. */
|
|
35
37
|
export type MysqlExecutorError = MysqlDriverError | RowDecodeError
|
|
@@ -172,7 +174,7 @@ export function make(
|
|
|
172
174
|
options: {
|
|
173
175
|
readonly renderer?: Renderer
|
|
174
176
|
readonly driverMode?: CoreExecutor.DriverMode
|
|
175
|
-
readonly valueMappings?:
|
|
177
|
+
readonly valueMappings?: ValueMappings
|
|
176
178
|
}
|
|
177
179
|
): QueryExecutor<SqlClient.SqlClient>
|
|
178
180
|
export function make<Error = never, Context = never>(
|
|
@@ -180,7 +182,7 @@ export function make<Error = never, Context = never>(
|
|
|
180
182
|
readonly renderer?: Renderer
|
|
181
183
|
readonly driver: Driver<Error, Context>
|
|
182
184
|
readonly driverMode?: CoreExecutor.DriverMode
|
|
183
|
-
readonly valueMappings?:
|
|
185
|
+
readonly valueMappings?: ValueMappings
|
|
184
186
|
}
|
|
185
187
|
): QueryExecutor<Context>
|
|
186
188
|
export function make<Error = never, Context = never>(
|
|
@@ -188,14 +190,14 @@ export function make<Error = never, Context = never>(
|
|
|
188
190
|
): QueryExecutor<any> {
|
|
189
191
|
if (options.driver) {
|
|
190
192
|
return fromDriver(
|
|
191
|
-
options.renderer ?? CoreRenderer.
|
|
193
|
+
options.renderer ?? CoreRenderer.makeTrusted("mysql", (plan) => renderMysqlPlan(plan, { valueMappings: options.valueMappings })),
|
|
192
194
|
options.driver,
|
|
193
195
|
options.driverMode,
|
|
194
196
|
options.valueMappings
|
|
195
197
|
)
|
|
196
198
|
}
|
|
197
199
|
return fromDriver(
|
|
198
|
-
options.renderer ?? CoreRenderer.
|
|
200
|
+
options.renderer ?? CoreRenderer.makeTrusted("mysql", (plan) => renderMysqlPlan(plan, { valueMappings: options.valueMappings })),
|
|
199
201
|
sqlClientDriver(),
|
|
200
202
|
options.driverMode,
|
|
201
203
|
options.valueMappings
|
|
@@ -1,7 +1,9 @@
|
|
|
1
|
-
import type
|
|
1
|
+
import { quoteBacktickIdentifier, type RenderState, type RenderValueContext, type SqlDialect } from "../../internal/dialect.js"
|
|
2
|
+
import { renderExpression, renderQueryAst } from "../../internal/dialect-renderers/mysql.js"
|
|
2
3
|
import { toDriverValue } from "../../internal/runtime/driver-value-mapping.js"
|
|
4
|
+
import { standardDialect } from "../../standard/dialect.js"
|
|
3
5
|
|
|
4
|
-
const quoteIdentifier =
|
|
6
|
+
const quoteIdentifier = quoteBacktickIdentifier
|
|
5
7
|
|
|
6
8
|
const renderLiteral = (value: unknown, state: RenderState, context: RenderValueContext = {}): string => {
|
|
7
9
|
const driverValue = toDriverValue(value, {
|
|
@@ -28,11 +30,12 @@ const renderLiteral = (value: unknown, state: RenderState, context: RenderValueC
|
|
|
28
30
|
* grows.
|
|
29
31
|
*/
|
|
30
32
|
export const mysqlDialect: SqlDialect<"mysql"> = {
|
|
33
|
+
...standardDialect,
|
|
31
34
|
name: "mysql",
|
|
32
35
|
quoteIdentifier,
|
|
33
36
|
renderLiteral,
|
|
34
37
|
renderTableReference(tableName, baseTableName, schemaName) {
|
|
35
|
-
const renderedBase = schemaName
|
|
38
|
+
const renderedBase = schemaName && schemaName !== "public"
|
|
36
39
|
? `${quoteIdentifier(schemaName)}.${quoteIdentifier(baseTableName)}`
|
|
37
40
|
: quoteIdentifier(baseTableName)
|
|
38
41
|
return tableName === baseTableName
|
|
@@ -41,5 +44,7 @@ export const mysqlDialect: SqlDialect<"mysql"> = {
|
|
|
41
44
|
},
|
|
42
45
|
renderConcat(values) {
|
|
43
46
|
return `concat(${values.join(", ")})`
|
|
44
|
-
}
|
|
47
|
+
},
|
|
48
|
+
renderQueryAst,
|
|
49
|
+
renderExpression
|
|
45
50
|
}
|