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.
74 lines (73 loc) • 3.46 kB
JavaScript
;
/* eslint-disable @typescript-eslint/no-explicit-any */
/* eslint-disable @typescript-eslint/no-unused-vars */
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 () {
var ownKeys = function(o) {
ownKeys = Object.getOwnPropertyNames || function (o) {
var ar = [];
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
return ar;
};
return ownKeys(o);
};
return function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
__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 Predicate_1 = require("effect/Predicate");
const Record = __importStar(require("effect/Record"));
const Schema = __importStar(require("effect/Schema"));
exports.ColumnTypesId = Symbol.for("effect-sql-kysely/ColumnTypesId");
const ColumnType = (select, insert, update) => {
return Object.assign(Schema.make(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.optional(schema), schema);
exports.Generated = Generated;
const GeneratedAlways = (schema) => (0, exports.ColumnType)(schema, Schema.Never, Schema.Never);
exports.GeneratedAlways = GeneratedAlways;
const JsonColumnType = (select, insert = Schema.String, update = Schema.String) => (0, exports.ColumnType)(select, insert, update);
exports.JsonColumnType = JsonColumnType;
const Table = (columns) => {
const select = Schema.Struct(Record.map(columns, (v) => ((0, exports.isColumnTypes)(v) ? v.select : v)));
const insert = Schema.Struct(Record.map(columns, (v) => ((0, exports.isColumnTypes)(v) ? v.insert : v)));
const update = Schema.Struct(Record.map(columns, (v) => ((0, exports.isColumnTypes)(v) ? v.update : v)));
return Object.assign(Schema.Struct(columns), {
[exports.ColumnTypesId]: exports.ColumnTypesId,
select,
insert,
update,
});
};
exports.Table = Table;