@tyravel/database 0.1.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/dist/connection.d.ts +15 -0
- package/dist/connection.d.ts.map +1 -0
- package/dist/connection.js +2 -0
- package/dist/connection.js.map +1 -0
- package/dist/database-manager.d.ts +12 -0
- package/dist/database-manager.d.ts.map +1 -0
- package/dist/database-manager.js +49 -0
- package/dist/database-manager.js.map +1 -0
- package/dist/grammar.d.ts +26 -0
- package/dist/grammar.d.ts.map +1 -0
- package/dist/grammar.js +31 -0
- package/dist/grammar.js.map +1 -0
- package/dist/grammar.test.d.ts +2 -0
- package/dist/grammar.test.d.ts.map +1 -0
- package/dist/grammar.test.js +48 -0
- package/dist/grammar.test.js.map +1 -0
- package/dist/index.d.ts +22 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +18 -0
- package/dist/index.js.map +1 -0
- package/dist/migration.d.ts +13 -0
- package/dist/migration.d.ts.map +1 -0
- package/dist/migration.js +3 -0
- package/dist/migration.js.map +1 -0
- package/dist/migrator.d.ts +15 -0
- package/dist/migrator.d.ts.map +1 -0
- package/dist/migrator.js +77 -0
- package/dist/migrator.js.map +1 -0
- package/dist/migrator.test.d.ts +2 -0
- package/dist/migrator.test.d.ts.map +1 -0
- package/dist/migrator.test.js +37 -0
- package/dist/migrator.test.js.map +1 -0
- package/dist/model-query-builder.d.ts +15 -0
- package/dist/model-query-builder.d.ts.map +1 -0
- package/dist/model-query-builder.js +43 -0
- package/dist/model-query-builder.js.map +1 -0
- package/dist/model-types.d.ts +14 -0
- package/dist/model-types.d.ts.map +1 -0
- package/dist/model-types.js +2 -0
- package/dist/model-types.js.map +1 -0
- package/dist/model.d.ts +41 -0
- package/dist/model.d.ts.map +1 -0
- package/dist/model.js +135 -0
- package/dist/model.js.map +1 -0
- package/dist/model.test.d.ts +2 -0
- package/dist/model.test.d.ts.map +1 -0
- package/dist/model.test.js +32 -0
- package/dist/model.test.js.map +1 -0
- package/dist/mysql-connection.d.ts +13 -0
- package/dist/mysql-connection.d.ts.map +1 -0
- package/dist/mysql-connection.js +85 -0
- package/dist/mysql-connection.js.map +1 -0
- package/dist/postgres-connection.d.ts +13 -0
- package/dist/postgres-connection.d.ts.map +1 -0
- package/dist/postgres-connection.js +81 -0
- package/dist/postgres-connection.js.map +1 -0
- package/dist/query-builder.d.ts +45 -0
- package/dist/query-builder.d.ts.map +1 -0
- package/dist/query-builder.js +167 -0
- package/dist/query-builder.js.map +1 -0
- package/dist/query-builder.test.d.ts +2 -0
- package/dist/query-builder.test.d.ts.map +1 -0
- package/dist/query-builder.test.js +37 -0
- package/dist/query-builder.test.js.map +1 -0
- package/dist/relations/belongs-to-many.d.ts +13 -0
- package/dist/relations/belongs-to-many.d.ts.map +1 -0
- package/dist/relations/belongs-to-many.js +38 -0
- package/dist/relations/belongs-to-many.js.map +1 -0
- package/dist/relations/belongs-to.d.ts +10 -0
- package/dist/relations/belongs-to.d.ts.map +1 -0
- package/dist/relations/belongs-to.js +21 -0
- package/dist/relations/belongs-to.js.map +1 -0
- package/dist/relations/has-many.d.ts +12 -0
- package/dist/relations/has-many.d.ts.map +1 -0
- package/dist/relations/has-many.js +18 -0
- package/dist/relations/has-many.js.map +1 -0
- package/dist/relations/has-one.d.ts +12 -0
- package/dist/relations/has-one.d.ts.map +1 -0
- package/dist/relations/has-one.js +18 -0
- package/dist/relations/has-one.js.map +1 -0
- package/dist/relations/relation.d.ts +9 -0
- package/dist/relations/relation.d.ts.map +1 -0
- package/dist/relations/relation.js +9 -0
- package/dist/relations/relation.js.map +1 -0
- package/dist/relations.test.d.ts +2 -0
- package/dist/relations.test.d.ts.map +1 -0
- package/dist/relations.test.js +78 -0
- package/dist/relations.test.js.map +1 -0
- package/dist/schema/blueprint.d.ts +16 -0
- package/dist/schema/blueprint.d.ts.map +1 -0
- package/dist/schema/blueprint.js +59 -0
- package/dist/schema/blueprint.js.map +1 -0
- package/dist/schema/schema-builder.d.ts +10 -0
- package/dist/schema/schema-builder.d.ts.map +1 -0
- package/dist/schema/schema-builder.js +21 -0
- package/dist/schema/schema-builder.js.map +1 -0
- package/dist/scopes.d.ts +5 -0
- package/dist/scopes.d.ts.map +1 -0
- package/dist/scopes.js +4 -0
- package/dist/scopes.js.map +1 -0
- package/dist/scopes.test.d.ts +2 -0
- package/dist/scopes.test.d.ts.map +1 -0
- package/dist/scopes.test.js +48 -0
- package/dist/scopes.test.js.map +1 -0
- package/dist/sqlite-connection.d.ts +12 -0
- package/dist/sqlite-connection.d.ts.map +1 -0
- package/dist/sqlite-connection.js +60 -0
- package/dist/sqlite-connection.js.map +1 -0
- package/dist/types.d.ts +37 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/dist/utils.d.ts +3 -0
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +15 -0
- package/dist/utils.js.map +1 -0
- package/package.json +40 -0
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { mkdirSync } from 'node:fs';
|
|
2
|
+
import { createRequire } from 'node:module';
|
|
3
|
+
import { dirname, resolve } from 'node:path';
|
|
4
|
+
import { SqliteGrammar } from './grammar.js';
|
|
5
|
+
export class SqliteConnection {
|
|
6
|
+
grammar = new SqliteGrammar();
|
|
7
|
+
database;
|
|
8
|
+
constructor(databasePath, basePath = process.cwd()) {
|
|
9
|
+
const resolvedPath = databasePath === ':memory:'
|
|
10
|
+
? ':memory:'
|
|
11
|
+
: resolve(basePath, databasePath);
|
|
12
|
+
if (resolvedPath !== ':memory:') {
|
|
13
|
+
mkdirSync(dirname(resolvedPath), { recursive: true });
|
|
14
|
+
}
|
|
15
|
+
const sqlite = loadSqliteModule();
|
|
16
|
+
this.database = new sqlite.DatabaseSync(resolvedPath);
|
|
17
|
+
}
|
|
18
|
+
async query(sql, bindings = []) {
|
|
19
|
+
const statement = this.database.prepare(sql);
|
|
20
|
+
const trimmed = sql.trim().toLowerCase();
|
|
21
|
+
if (trimmed.startsWith('select') || trimmed.startsWith('pragma')) {
|
|
22
|
+
const rows = statement.all(...normalizeBindings(bindings));
|
|
23
|
+
return { rows, changes: 0 };
|
|
24
|
+
}
|
|
25
|
+
const result = statement.run(...normalizeBindings(bindings));
|
|
26
|
+
return {
|
|
27
|
+
rows: [],
|
|
28
|
+
changes: result.changes,
|
|
29
|
+
lastInsertId: result.lastInsertRowid,
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
async exec(sql) {
|
|
33
|
+
this.database.exec(sql);
|
|
34
|
+
}
|
|
35
|
+
async transaction(callback) {
|
|
36
|
+
await this.exec('BEGIN');
|
|
37
|
+
try {
|
|
38
|
+
const result = await callback(this);
|
|
39
|
+
await this.exec('COMMIT');
|
|
40
|
+
return result;
|
|
41
|
+
}
|
|
42
|
+
catch (error) {
|
|
43
|
+
await this.exec('ROLLBACK');
|
|
44
|
+
throw error;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
const require = createRequire(import.meta.url);
|
|
49
|
+
function loadSqliteModule() {
|
|
50
|
+
try {
|
|
51
|
+
return require('node:sqlite');
|
|
52
|
+
}
|
|
53
|
+
catch {
|
|
54
|
+
throw new Error('SQLite support requires Node.js 22.5+ with the built-in node:sqlite module.');
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
function normalizeBindings(bindings) {
|
|
58
|
+
return bindings.map((binding) => (binding === undefined ? null : binding));
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=sqlite-connection.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sqlite-connection.js","sourceRoot":"","sources":["../src/sqlite-connection.ts"],"names":[],"mappings":"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"}
|
package/dist/types.d.ts
ADDED
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
export type Row = Record<string, unknown>;
|
|
2
|
+
export type RowValue = string | number | bigint | boolean | null | undefined;
|
|
3
|
+
export type WhereOperator = '=' | '!=' | '<' | '>' | '<=' | '>=' | 'like' | 'in';
|
|
4
|
+
export interface WhereClause {
|
|
5
|
+
type: 'basic' | 'in';
|
|
6
|
+
column: string;
|
|
7
|
+
operator: WhereOperator;
|
|
8
|
+
value: unknown;
|
|
9
|
+
boolean: 'and' | 'or';
|
|
10
|
+
}
|
|
11
|
+
export interface SqliteConnectionConfig {
|
|
12
|
+
driver: 'sqlite';
|
|
13
|
+
database: string;
|
|
14
|
+
}
|
|
15
|
+
export interface PostgresConnectionConfig {
|
|
16
|
+
driver: 'postgres';
|
|
17
|
+
host: string;
|
|
18
|
+
port?: number;
|
|
19
|
+
database: string;
|
|
20
|
+
username: string;
|
|
21
|
+
password: string;
|
|
22
|
+
ssl?: boolean;
|
|
23
|
+
}
|
|
24
|
+
export interface MysqlConnectionConfig {
|
|
25
|
+
driver: 'mysql';
|
|
26
|
+
host: string;
|
|
27
|
+
port?: number;
|
|
28
|
+
database: string;
|
|
29
|
+
username: string;
|
|
30
|
+
password: string;
|
|
31
|
+
}
|
|
32
|
+
export type ConnectionConfig = SqliteConnectionConfig | PostgresConnectionConfig | MysqlConnectionConfig;
|
|
33
|
+
export interface DatabaseConfig {
|
|
34
|
+
default: string;
|
|
35
|
+
connections: Record<string, ConnectionConfig>;
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,GAAG,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AAC1C,MAAM,MAAM,QAAQ,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,IAAI,GAAG,SAAS,CAAC;AAC7E,MAAM,MAAM,aAAa,GAAG,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,IAAI,GAAG,MAAM,GAAG,IAAI,CAAC;AAEjF,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,OAAO,GAAG,IAAI,CAAC;IACrB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,aAAa,CAAC;IACxB,KAAK,EAAE,OAAO,CAAC;IACf,OAAO,EAAE,KAAK,GAAG,IAAI,CAAC;CACvB;AAED,MAAM,WAAW,sBAAsB;IACrC,MAAM,EAAE,QAAQ,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,wBAAwB;IACvC,MAAM,EAAE,UAAU,CAAC;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,GAAG,CAAC,EAAE,OAAO,CAAC;CACf;AAED,MAAM,WAAW,qBAAqB;IACpC,MAAM,EAAE,OAAO,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,MAAM,gBAAgB,GACxB,sBAAsB,GACtB,wBAAwB,GACxB,qBAAqB,CAAC;AAE1B,MAAM,WAAW,cAAc;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;CAC/C"}
|
package/dist/types.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}
|
package/dist/utils.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":"AAAA,wBAAgB,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAM/C;AAED,wBAAgB,iBAAiB,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CAM3D"}
|
package/dist/utils.js
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export function snakeCase(value) {
|
|
2
|
+
return value
|
|
3
|
+
.replace(/([a-z0-9])([A-Z])/g, '$1_$2')
|
|
4
|
+
.replace(/[^a-zA-Z0-9]+/g, '_')
|
|
5
|
+
.replace(/^_+|_+$/g, '')
|
|
6
|
+
.toLowerCase();
|
|
7
|
+
}
|
|
8
|
+
export function singularSnakeCase(modelName) {
|
|
9
|
+
const snake = snakeCase(modelName);
|
|
10
|
+
if (snake.endsWith('s')) {
|
|
11
|
+
return snake.slice(0, -1);
|
|
12
|
+
}
|
|
13
|
+
return snake;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,SAAS,CAAC,KAAa;IACrC,OAAO,KAAK;SACT,OAAO,CAAC,oBAAoB,EAAE,OAAO,CAAC;SACtC,OAAO,CAAC,gBAAgB,EAAE,GAAG,CAAC;SAC9B,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC;SACvB,WAAW,EAAE,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,SAAiB;IACjD,MAAM,KAAK,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC;IACnC,IAAI,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;QACxB,OAAO,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC"}
|
package/package.json
ADDED
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@tyravel/database",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"type": "module",
|
|
5
|
+
"main": "./dist/index.js",
|
|
6
|
+
"types": "./dist/index.d.ts",
|
|
7
|
+
"exports": {
|
|
8
|
+
".": {
|
|
9
|
+
"types": "./dist/index.d.ts",
|
|
10
|
+
"import": "./dist/index.js"
|
|
11
|
+
}
|
|
12
|
+
},
|
|
13
|
+
"scripts": {
|
|
14
|
+
"build": "tsc -p tsconfig.json",
|
|
15
|
+
"typecheck": "tsc -p tsconfig.json --noEmit"
|
|
16
|
+
},
|
|
17
|
+
"files": [
|
|
18
|
+
"dist"
|
|
19
|
+
],
|
|
20
|
+
"engines": {
|
|
21
|
+
"node": ">=22"
|
|
22
|
+
},
|
|
23
|
+
"dependencies": {
|
|
24
|
+
"mysql2": "^3.14.1",
|
|
25
|
+
"pg": "^8.16.0"
|
|
26
|
+
},
|
|
27
|
+
"devDependencies": {
|
|
28
|
+
"@types/pg": "^8.15.4"
|
|
29
|
+
},
|
|
30
|
+
"description": "Database ORM, query builder, and migrations for Tyravel",
|
|
31
|
+
"license": "MIT",
|
|
32
|
+
"repository": {
|
|
33
|
+
"type": "git",
|
|
34
|
+
"url": "git+https://github.com/thesimonharms/tyravel.git",
|
|
35
|
+
"directory": "packages/database"
|
|
36
|
+
},
|
|
37
|
+
"publishConfig": {
|
|
38
|
+
"access": "public"
|
|
39
|
+
}
|
|
40
|
+
}
|