UNPKG

effect-sql-kysely

Version:

A full-featured integration between `@effect/sql` and `Kysely` that provides type-safe database operations with Effect's powerful error handling and resource management.

33 lines (32 loc) 2.32 kB
import * as kysely from "kysely"; import * as Context from "effect/Context"; import * as Effect from "effect/Effect"; import * as Sql from "@effect/sql"; import type { Schema } from "@effect/schema"; import * as Option from "effect/Option"; import type { Types } from "effect"; import type { KyselyDatabase } from "../Database.js"; export declare function makeResolver<ID, DB>(Tag: Context.Tag<ID, KyselyDatabase<DB>>): { readonly findById: <T extends string, I, II, RI, A, IA, Row extends object>(tag: T, options: { readonly Id: Schema.Schema<I, II, RI>; readonly Result: Schema.Schema<A, IA, never>; readonly ResultId: (result: Types.NoInfer<A>, row: Types.NoInfer<Row>) => II; readonly execute: (db: kysely.Kysely<DB>, requests: Array<Types.NoInfer<II>>) => kysely.Compilable<Row>; }) => Effect.Effect<Sql.SqlResolver.SqlResolver<T, I, Option.Option<A>, Sql.SqlError.SqlError, RI>, never, ID>; readonly grouped: <T extends string, I, II, K, RI, A, IA, Row extends object>(tag: T, options: { readonly Request: Schema.Schema<I, II, RI>; readonly RequestGroupKey: (request: Types.NoInfer<II>) => K; readonly Result: Schema.Schema<A, IA, never>; readonly ResultGroupKey: (result: Types.NoInfer<A>, row: Types.NoInfer<Row>) => K; readonly execute: (db: kysely.Kysely<DB>, requests: Array<Types.NoInfer<II>>) => kysely.Compilable<Row>; }) => Effect.Effect<Sql.SqlResolver.SqlResolver<T, I, Array<A>, Sql.SqlError.SqlError, RI>, never, ID>; readonly ordered: <T extends string, I, II, RI, A, IA extends object>(tag: T, options: { readonly Request: Schema.Schema<I, II, RI>; readonly Result: Schema.Schema<A, IA, never>; readonly execute: (db: kysely.Kysely<DB>, requests: Array<Types.NoInfer<II>>) => kysely.Compilable<IA>; }) => Effect.Effect<Sql.SqlResolver.SqlResolver<T, I, A, Sql.SqlError.ResultLengthMismatch | Sql.SqlError.SqlError, RI>, never, ID>; readonly void: <T extends string, I, II, RI>(tag: T, options: { readonly Request: Schema.Schema<I, II, RI>; readonly execute: (db: kysely.Kysely<DB>, requests: Array<Types.NoInfer<II>>) => kysely.Compilable<object>; }) => Effect.Effect<Sql.SqlResolver.SqlResolver<T, I, void, Sql.SqlError.SqlError, RI>, never, ID>; };