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.
63 lines (62 loc) • 3.16 kB
JavaScript
;
/* eslint-disable @typescript-eslint/no-explicit-any */
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.Table = exports.JsonColumnType = exports.GeneratedAlways = exports.Generated = exports.isColumnTypes = exports.ColumnType = exports.ColumnTypesId = void 0;
const schema_1 = require("@effect/schema");
const Predicate_1 = require("effect/Predicate");
const Record = __importStar(require("effect/Record"));
exports.ColumnTypesId = Symbol.for("effect-sql-kysely/ColumnTypesId");
const ColumnType = (select, insert, update) => {
return Object.assign(schema_1.Schema.make(schema_1.Schema.Never.ast).annotations({
message: () => `ColumnType Schema is not intended to be used directly. Utilize ColumnType.[select|insert|update]`,
}), {
[exports.ColumnTypesId]: exports.ColumnTypesId,
select,
insert,
update,
});
};
exports.ColumnType = ColumnType;
const isColumnTypes = (value) => (0, Predicate_1.hasProperty)(value, exports.ColumnTypesId);
exports.isColumnTypes = isColumnTypes;
const Generated = (schema) => (0, exports.ColumnType)(schema, schema_1.Schema.UndefinedOr(schema), schema);
exports.Generated = Generated;
const GeneratedAlways = (schema) => (0, exports.ColumnType)(schema, schema_1.Schema.Never, schema_1.Schema.Never);
exports.GeneratedAlways = GeneratedAlways;
const JsonColumnType = (select, insert = schema_1.Schema.String, update = schema_1.Schema.String) => (0, exports.ColumnType)(select, insert, update);
exports.JsonColumnType = JsonColumnType;
const Table = (columns) => {
const select = schema_1.Schema.Struct(Record.map(columns, (v) => ((0, exports.isColumnTypes)(v) ? v.select : v)));
const insert = schema_1.Schema.Struct(Record.map(columns, (v) => ((0, exports.isColumnTypes)(v) ? v.insert : v)));
const update = schema_1.Schema.Struct(Record.map(columns, (v) => ((0, exports.isColumnTypes)(v) ? v.update : v)));
return Object.assign(schema_1.Schema.Struct(columns), {
[exports.ColumnTypesId]: exports.ColumnTypesId,
select,
insert,
update,
});
};
exports.Table = Table;