@skalfa/skalfa-api-core 1.0.2
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/.github/workflows/publish.yml +40 -0
- package/dist/auth/auth.d.ts +19 -0
- package/dist/auth/auth.js +227 -0
- package/dist/auth/auth.js.map +1 -0
- package/dist/auth/index.d.ts +1 -0
- package/dist/auth/index.js +2 -0
- package/dist/auth/index.js.map +1 -0
- package/dist/auth.util.d.ts +19 -0
- package/dist/auth.util.js +183 -0
- package/dist/auth.util.js.map +1 -0
- package/dist/commands/cli.d.ts +1 -0
- package/dist/commands/cli.js +78 -0
- package/dist/commands/cli.js.map +1 -0
- package/dist/commands/make/basic-controller.d.ts +2 -0
- package/dist/commands/make/basic-controller.js +40 -0
- package/dist/commands/make/basic-controller.js.map +1 -0
- package/dist/commands/make/basic-migration.d.ts +5 -0
- package/dist/commands/make/basic-migration.js +60 -0
- package/dist/commands/make/basic-migration.js.map +1 -0
- package/dist/commands/make/basic-model.d.ts +2 -0
- package/dist/commands/make/basic-model.js +25 -0
- package/dist/commands/make/basic-model.js.map +1 -0
- package/dist/commands/make/basic-seeder.d.ts +3 -0
- package/dist/commands/make/basic-seeder.js +32 -0
- package/dist/commands/make/basic-seeder.js.map +1 -0
- package/dist/commands/make/blueprint.d.ts +2 -0
- package/dist/commands/make/blueprint.js +29 -0
- package/dist/commands/make/blueprint.js.map +1 -0
- package/dist/commands/make/da-migration.d.ts +5 -0
- package/dist/commands/make/da-migration.js +60 -0
- package/dist/commands/make/da-migration.js.map +1 -0
- package/dist/commands/make/light-controller.d.ts +3 -0
- package/dist/commands/make/light-controller.js +54 -0
- package/dist/commands/make/light-controller.js.map +1 -0
- package/dist/commands/make/light-model.d.ts +3 -0
- package/dist/commands/make/light-model.js +50 -0
- package/dist/commands/make/light-model.js.map +1 -0
- package/dist/commands/make/mail.d.ts +2 -0
- package/dist/commands/make/mail.js +41 -0
- package/dist/commands/make/mail.js.map +1 -0
- package/dist/commands/make/notification.d.ts +2 -0
- package/dist/commands/make/notification.js +33 -0
- package/dist/commands/make/notification.js.map +1 -0
- package/dist/commands/make/queue.d.ts +2 -0
- package/dist/commands/make/queue.js +35 -0
- package/dist/commands/make/queue.js.map +1 -0
- package/dist/commands/runner/barrels.d.ts +3 -0
- package/dist/commands/runner/barrels.js +78 -0
- package/dist/commands/runner/barrels.js.map +1 -0
- package/dist/commands/runner/blueprint/controller-generation.d.ts +1 -0
- package/dist/commands/runner/blueprint/controller-generation.js +147 -0
- package/dist/commands/runner/blueprint/controller-generation.js.map +1 -0
- package/dist/commands/runner/blueprint/documentation-generation.d.ts +6 -0
- package/dist/commands/runner/blueprint/documentation-generation.js +337 -0
- package/dist/commands/runner/blueprint/documentation-generation.js.map +1 -0
- package/dist/commands/runner/blueprint/migration-generation.d.ts +1 -0
- package/dist/commands/runner/blueprint/migration-generation.js +120 -0
- package/dist/commands/runner/blueprint/migration-generation.js.map +1 -0
- package/dist/commands/runner/blueprint/model-generation.d.ts +1 -0
- package/dist/commands/runner/blueprint/model-generation.js +122 -0
- package/dist/commands/runner/blueprint/model-generation.js.map +1 -0
- package/dist/commands/runner/blueprint/runner.d.ts +23 -0
- package/dist/commands/runner/blueprint/runner.js +139 -0
- package/dist/commands/runner/blueprint/runner.js.map +1 -0
- package/dist/commands/runner/blueprint/seeder-generation.d.ts +1 -0
- package/dist/commands/runner/blueprint/seeder-generation.js +40 -0
- package/dist/commands/runner/blueprint/seeder-generation.js.map +1 -0
- package/dist/commands/runner/da-migration.d.ts +39 -0
- package/dist/commands/runner/da-migration.js +262 -0
- package/dist/commands/runner/da-migration.js.map +1 -0
- package/dist/commands/runner/migration.d.ts +11 -0
- package/dist/commands/runner/migration.js +188 -0
- package/dist/commands/runner/migration.js.map +1 -0
- package/dist/commands/runner/seeder.d.ts +3 -0
- package/dist/commands/runner/seeder.js +40 -0
- package/dist/commands/runner/seeder.js.map +1 -0
- package/dist/commands/stubs/index.d.ts +14 -0
- package/dist/commands/stubs/index.js +277 -0
- package/dist/commands/stubs/index.js.map +1 -0
- package/dist/context/context.d.ts +7 -0
- package/dist/context/context.js +11 -0
- package/dist/context/context.js.map +1 -0
- package/dist/context/index.d.ts +1 -0
- package/dist/context/index.js +2 -0
- package/dist/context/index.js.map +1 -0
- package/dist/context.util.d.ts +7 -0
- package/dist/context.util.js +11 -0
- package/dist/context.util.js.map +1 -0
- package/dist/controller/controller.d.ts +118 -0
- package/dist/controller/controller.js +147 -0
- package/dist/controller/controller.js.map +1 -0
- package/dist/controller/index.d.ts +1 -0
- package/dist/controller/index.js +2 -0
- package/dist/controller/index.js.map +1 -0
- package/dist/controller.util.d.ts +118 -0
- package/dist/controller.util.js +144 -0
- package/dist/controller.util.js.map +1 -0
- package/dist/conversion/conversion.d.ts +8 -0
- package/dist/conversion/conversion.js +52 -0
- package/dist/conversion/conversion.js.map +1 -0
- package/dist/conversion/index.d.ts +1 -0
- package/dist/conversion/index.js +2 -0
- package/dist/conversion/index.js.map +1 -0
- package/dist/conversion.util.d.ts +8 -0
- package/dist/conversion.util.js +52 -0
- package/dist/conversion.util.js.map +1 -0
- package/dist/db/db.d.ts +84 -0
- package/dist/db/db.js +177 -0
- package/dist/db/db.js.map +1 -0
- package/dist/db/index.d.ts +1 -0
- package/dist/db/index.js +2 -0
- package/dist/db/index.js.map +1 -0
- package/dist/db.util.d.ts +84 -0
- package/dist/db.util.js +177 -0
- package/dist/db.util.js.map +1 -0
- package/dist/index.d.ts +21 -0
- package/dist/index.js +14 -0
- package/dist/index.js.map +1 -0
- package/dist/logger/index.d.ts +1 -0
- package/dist/logger/index.js +2 -0
- package/dist/logger/index.js.map +1 -0
- package/dist/logger/logger.d.ts +30 -0
- package/dist/logger/logger.js +126 -0
- package/dist/logger/logger.js.map +1 -0
- package/dist/logger.util.d.ts +30 -0
- package/dist/logger.util.js +126 -0
- package/dist/logger.util.js.map +1 -0
- package/dist/mail/index.d.ts +1 -0
- package/dist/mail/index.js +2 -0
- package/dist/mail/index.js.map +1 -0
- package/dist/mail/mail.d.ts +21 -0
- package/dist/mail/mail.js +53 -0
- package/dist/mail/mail.js.map +1 -0
- package/dist/mail.util.d.ts +21 -0
- package/dist/mail.util.js +53 -0
- package/dist/mail.util.js.map +1 -0
- package/dist/middleware/index.d.ts +1 -0
- package/dist/middleware/index.js +2 -0
- package/dist/middleware/index.js.map +1 -0
- package/dist/middleware/middleware.d.ts +263 -0
- package/dist/middleware/middleware.js +233 -0
- package/dist/middleware/middleware.js.map +1 -0
- package/dist/middleware.util.d.ts +263 -0
- package/dist/middleware.util.js +233 -0
- package/dist/middleware.util.js.map +1 -0
- package/dist/model/index.d.ts +3 -0
- package/dist/model/index.js +4 -0
- package/dist/model/index.js.map +1 -0
- package/dist/model/model.d.ts +204 -0
- package/dist/model/model.js +1495 -0
- package/dist/model/model.js.map +1 -0
- package/dist/model.util.d.ts +204 -0
- package/dist/model.util.js +1495 -0
- package/dist/model.util.js.map +1 -0
- package/dist/permission/index.d.ts +1 -0
- package/dist/permission/index.js +2 -0
- package/dist/permission/index.js.map +1 -0
- package/dist/permission/permission.d.ts +38 -0
- package/dist/permission/permission.js +91 -0
- package/dist/permission/permission.js.map +1 -0
- package/dist/permission.util.d.ts +38 -0
- package/dist/permission.util.js +91 -0
- package/dist/permission.util.js.map +1 -0
- package/dist/registry/index.d.ts +1 -0
- package/dist/registry/index.js +2 -0
- package/dist/registry/index.js.map +1 -0
- package/dist/registry/registry.d.ts +28 -0
- package/dist/registry/registry.js +19 -0
- package/dist/registry/registry.js.map +1 -0
- package/dist/registry.util.d.ts +28 -0
- package/dist/registry.util.js +19 -0
- package/dist/registry.util.js.map +1 -0
- package/dist/route/index.d.ts +1 -0
- package/dist/route/index.js +2 -0
- package/dist/route/index.js.map +1 -0
- package/dist/route/route.d.ts +1 -0
- package/dist/route/route.js +12 -0
- package/dist/route/route.js.map +1 -0
- package/dist/route.util.d.ts +1 -0
- package/dist/route.util.js +12 -0
- package/dist/route.util.js.map +1 -0
- package/dist/storage/index.d.ts +1 -0
- package/dist/storage/index.js +2 -0
- package/dist/storage/index.js.map +1 -0
- package/dist/storage/storage.d.ts +56 -0
- package/dist/storage/storage.js +86 -0
- package/dist/storage/storage.js.map +1 -0
- package/dist/storage.util.d.ts +56 -0
- package/dist/storage.util.js +82 -0
- package/dist/storage.util.js.map +1 -0
- package/dist/validation/index.d.ts +1 -0
- package/dist/validation/index.js +2 -0
- package/dist/validation/index.js.map +1 -0
- package/dist/validation/validation.d.ts +7 -0
- package/dist/validation/validation.js +245 -0
- package/dist/validation/validation.js.map +1 -0
- package/dist/validation.util.d.ts +7 -0
- package/dist/validation.util.js +237 -0
- package/dist/validation.util.js.map +1 -0
- package/package.json +34 -0
- package/src/auth/auth.ts +282 -0
- package/src/auth/index.ts +1 -0
- package/src/commands/cli.ts +89 -0
- package/src/commands/make/basic-controller.ts +49 -0
- package/src/commands/make/basic-migration.ts +89 -0
- package/src/commands/make/basic-model.ts +32 -0
- package/src/commands/make/basic-seeder.ts +38 -0
- package/src/commands/make/blueprint.ts +36 -0
- package/src/commands/make/da-migration.ts +90 -0
- package/src/commands/make/light-controller.ts +67 -0
- package/src/commands/make/light-model.ts +61 -0
- package/src/commands/make/mail.ts +51 -0
- package/src/commands/make/notification.ts +43 -0
- package/src/commands/make/queue.ts +45 -0
- package/src/commands/runner/barrels.ts +85 -0
- package/src/commands/runner/blueprint/controller-generation.ts +194 -0
- package/src/commands/runner/blueprint/documentation-generation.ts +463 -0
- package/src/commands/runner/blueprint/migration-generation.ts +153 -0
- package/src/commands/runner/blueprint/model-generation.ts +149 -0
- package/src/commands/runner/blueprint/runner.ts +181 -0
- package/src/commands/runner/blueprint/seeder-generation.ts +55 -0
- package/src/commands/runner/da-migration.ts +333 -0
- package/src/commands/runner/migration.ts +245 -0
- package/src/commands/runner/seeder.ts +44 -0
- package/src/commands/stubs/index.ts +289 -0
- package/src/context/context.ts +17 -0
- package/src/context/index.ts +1 -0
- package/src/controller/controller.ts +240 -0
- package/src/controller/index.ts +1 -0
- package/src/conversion/conversion.ts +65 -0
- package/src/conversion/index.ts +1 -0
- package/src/index.ts +22 -0
- package/src/logger/index.ts +1 -0
- package/src/logger/logger.ts +177 -0
- package/src/mail/index.ts +1 -0
- package/src/mail/mail.ts +86 -0
- package/src/middleware/index.ts +1 -0
- package/src/middleware/middleware.ts +289 -0
- package/src/permission/index.ts +1 -0
- package/src/permission/permission.ts +136 -0
- package/src/registry/index.ts +1 -0
- package/src/registry/registry.ts +37 -0
- package/src/route/index.ts +1 -0
- package/src/route/route.ts +12 -0
- package/src/storage/index.ts +1 -0
- package/src/storage/storage.ts +107 -0
- package/src/validation/index.ts +1 -0
- package/src/validation/validation.ts +346 -0
- package/tsconfig.json +23 -0
package/dist/db/db.js
ADDED
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
import knex from 'knex';
|
|
2
|
+
import { conversion } from '@utils/conversion';
|
|
3
|
+
// ==============================
|
|
4
|
+
// ## Driver resolver
|
|
5
|
+
// ==============================
|
|
6
|
+
function resolveDriver(conn) {
|
|
7
|
+
if (!conn)
|
|
8
|
+
return 'pg';
|
|
9
|
+
const v = conn.toLowerCase();
|
|
10
|
+
if (['pg', 'pgsql', 'postgres'].includes(v))
|
|
11
|
+
return 'pg';
|
|
12
|
+
if (['mysql', 'mysql2'].includes(v))
|
|
13
|
+
return 'mysql2';
|
|
14
|
+
throw new Error(`Unsupported DB_CONNECTION: ${conn}`);
|
|
15
|
+
}
|
|
16
|
+
// ==============================
|
|
17
|
+
// ## Knex factory
|
|
18
|
+
// ==============================
|
|
19
|
+
function createKnex(config) {
|
|
20
|
+
const client = resolveDriver(config.client);
|
|
21
|
+
return knex({
|
|
22
|
+
client,
|
|
23
|
+
connection: {
|
|
24
|
+
host: config.host ?? '127.0.0.1',
|
|
25
|
+
port: config.port ?? (client === 'mysql2' ? 3306 : 5432),
|
|
26
|
+
user: config.user ?? 'postgres',
|
|
27
|
+
password: config.password ?? 'password',
|
|
28
|
+
database: config.database ?? 'db_elysia_light',
|
|
29
|
+
},
|
|
30
|
+
pool: { min: 2, max: 10 },
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
// ==============================
|
|
34
|
+
// ## Connection registry
|
|
35
|
+
// ==============================
|
|
36
|
+
const connections = {};
|
|
37
|
+
// ==============================
|
|
38
|
+
// ## Default connection
|
|
39
|
+
// ==============================
|
|
40
|
+
const DEFAULT_NAME = 'default';
|
|
41
|
+
connections[DEFAULT_NAME] = createKnex({
|
|
42
|
+
client: process.env.DB_CONNECTION,
|
|
43
|
+
host: process.env.DB_HOST,
|
|
44
|
+
port: Number(process.env.DB_PORT),
|
|
45
|
+
user: process.env.DB_USERNAME,
|
|
46
|
+
password: process.env.DB_PASSWORD,
|
|
47
|
+
database: process.env.DB_DATABASE,
|
|
48
|
+
});
|
|
49
|
+
// ==============================
|
|
50
|
+
// ## Export default db
|
|
51
|
+
// ==============================
|
|
52
|
+
export const db = connections[DEFAULT_NAME];
|
|
53
|
+
// ==============================
|
|
54
|
+
// ## Named connection (multiple DB)
|
|
55
|
+
// ==============================
|
|
56
|
+
export function useDB(name, config) {
|
|
57
|
+
if (!connections[name]) {
|
|
58
|
+
if (!config) {
|
|
59
|
+
throw new Error(`DB connection "${name}" not found`);
|
|
60
|
+
}
|
|
61
|
+
connections[name] = createKnex(config);
|
|
62
|
+
}
|
|
63
|
+
return connections[name];
|
|
64
|
+
}
|
|
65
|
+
// ==============================
|
|
66
|
+
// ## Close all connections (CLI safe)
|
|
67
|
+
// ==============================
|
|
68
|
+
export async function closeAllDB() {
|
|
69
|
+
await Promise.all(Object.values(connections).map(db => db.destroy()));
|
|
70
|
+
}
|
|
71
|
+
// ==============================
|
|
72
|
+
// ## Schema Builder Extensions
|
|
73
|
+
// ==============================
|
|
74
|
+
knex.TableBuilder.extend("softDelete", function () {
|
|
75
|
+
return this.timestamp("deleted_at").nullable();
|
|
76
|
+
});
|
|
77
|
+
knex.TableBuilder.extend("foreignIdFor", function (tableName, columnName) {
|
|
78
|
+
const col = columnName || `${conversion.strSingular(tableName)}_id`;
|
|
79
|
+
return this.bigInteger(col).unsigned().references("id").inTable(tableName);
|
|
80
|
+
});
|
|
81
|
+
function getBaseTable(qb) {
|
|
82
|
+
return qb._single?.table;
|
|
83
|
+
}
|
|
84
|
+
function buildWhereHas(qb, type, table, localKeyOrRelation, foreignKey, callback) {
|
|
85
|
+
const baseTable = getBaseTable(qb);
|
|
86
|
+
if (!baseTable) {
|
|
87
|
+
throw new Error("whereHas harus dipanggil setelah table()");
|
|
88
|
+
}
|
|
89
|
+
qb.select(1).from(table);
|
|
90
|
+
if (type != "BELONGSTOMANY") {
|
|
91
|
+
qb.whereRaw(`${foreignKey} = ${baseTable}.${localKeyOrRelation}`);
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
const r = localKeyOrRelation;
|
|
95
|
+
qb.join(r.pivotTable, `${r.pivotTable}.${r.pivotForeignKey}`, `${table}.${r.foreignKey}`).whereRaw(`${r.pivotTable}.${r.pivotLocalKey} = ${baseTable}.${r.localKey}`);
|
|
96
|
+
}
|
|
97
|
+
if (callback)
|
|
98
|
+
callback(qb);
|
|
99
|
+
}
|
|
100
|
+
knex.QueryBuilder.extend("joinWith", function (type, table, relation, as, callback) {
|
|
101
|
+
const baseTable = getBaseTable(this);
|
|
102
|
+
if (!baseTable)
|
|
103
|
+
throw new Error("joinWith() must be after table()");
|
|
104
|
+
let subquery = null;
|
|
105
|
+
if (type === "BELONGSTO") {
|
|
106
|
+
const r = relation;
|
|
107
|
+
subquery = `
|
|
108
|
+
(
|
|
109
|
+
select row_to_json(${table})
|
|
110
|
+
from ${table}
|
|
111
|
+
where ${table}.${r.foreignKey} = ${baseTable}.${r.localKey}
|
|
112
|
+
limit 1
|
|
113
|
+
)
|
|
114
|
+
`;
|
|
115
|
+
}
|
|
116
|
+
if (type === "HASONE") {
|
|
117
|
+
const r = relation;
|
|
118
|
+
subquery = `
|
|
119
|
+
(
|
|
120
|
+
select row_to_json(${table})
|
|
121
|
+
from ${table}
|
|
122
|
+
where ${table}.${r.foreignKey} = ${baseTable}.${r.localKey}
|
|
123
|
+
limit 1
|
|
124
|
+
)
|
|
125
|
+
`;
|
|
126
|
+
}
|
|
127
|
+
if (type === "HASMANY") {
|
|
128
|
+
const r = relation;
|
|
129
|
+
subquery = `
|
|
130
|
+
(
|
|
131
|
+
select coalesce(json_agg(${table}), '[]'::json)
|
|
132
|
+
from ${table}
|
|
133
|
+
where ${table}.${r.foreignKey} = ${baseTable}.${r.localKey}
|
|
134
|
+
)
|
|
135
|
+
`;
|
|
136
|
+
}
|
|
137
|
+
if (type === "BELONGSTOMANY") {
|
|
138
|
+
const r = relation;
|
|
139
|
+
subquery = `
|
|
140
|
+
(
|
|
141
|
+
select coalesce(json_agg(${table}), '[]'::json)
|
|
142
|
+
from ${table}
|
|
143
|
+
inner join ${r.pivotTable}
|
|
144
|
+
on ${r.pivotTable}.${r.pivotForeignKey} = ${table}.${r.foreignKey}
|
|
145
|
+
where ${r.pivotTable}.${r.pivotLocalKey} = ${baseTable}.${r.localKey}
|
|
146
|
+
)
|
|
147
|
+
`;
|
|
148
|
+
}
|
|
149
|
+
if (!subquery) {
|
|
150
|
+
throw new Error(`Unsupported relation type: ${type}`);
|
|
151
|
+
}
|
|
152
|
+
if (callback) {
|
|
153
|
+
callback(this);
|
|
154
|
+
}
|
|
155
|
+
return this.select(this.client.raw(`${subquery} as "${as}"`));
|
|
156
|
+
});
|
|
157
|
+
knex.QueryBuilder.extend("whereJoinHas", function (type, table, localKeyOrRelation, foreignKey, callback) {
|
|
158
|
+
return this.whereExists(function () {
|
|
159
|
+
buildWhereHas(this, type, table, localKeyOrRelation, foreignKey, callback);
|
|
160
|
+
});
|
|
161
|
+
});
|
|
162
|
+
knex.QueryBuilder.extend("orJoinWhereHas", function (type, table, localKeyOrRelation, foreignKey, callback) {
|
|
163
|
+
return this.orWhereExists(function () {
|
|
164
|
+
buildWhereHas(this, type, table, localKeyOrRelation, foreignKey, callback);
|
|
165
|
+
});
|
|
166
|
+
});
|
|
167
|
+
knex.QueryBuilder.extend("whereJoinDoesntHave", function (type, table, localKeyOrRelation, foreignKey, callback) {
|
|
168
|
+
return this.whereNotExists(function () {
|
|
169
|
+
buildWhereHas(this, type, table, localKeyOrRelation, foreignKey, callback);
|
|
170
|
+
});
|
|
171
|
+
});
|
|
172
|
+
knex.QueryBuilder.extend("orWhereJoinDoesntHave", function (type, table, localKeyOrRelation, foreignKey, callback) {
|
|
173
|
+
return this.orWhereNotExists(function () {
|
|
174
|
+
buildWhereHas(this, type, table, localKeyOrRelation, foreignKey, callback);
|
|
175
|
+
});
|
|
176
|
+
});
|
|
177
|
+
//# sourceMappingURL=db.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"db.js","sourceRoot":"","sources":["../../src/db/db.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const db: any;
|
package/dist/db/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/db/index.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,EAAE,GAAQ,IAAI,CAAC"}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { Knex } from 'knex';
|
|
2
|
+
export declare const db: Knex;
|
|
3
|
+
export declare function useDB(name: string, config?: {
|
|
4
|
+
client?: string;
|
|
5
|
+
host?: string;
|
|
6
|
+
port?: number;
|
|
7
|
+
user?: string;
|
|
8
|
+
password?: string;
|
|
9
|
+
database?: string;
|
|
10
|
+
}): Knex;
|
|
11
|
+
export declare function closeAllDB(): Promise<void>;
|
|
12
|
+
declare module "knex" {
|
|
13
|
+
namespace Knex {
|
|
14
|
+
interface TableBuilder {
|
|
15
|
+
softDelete(): Knex.ColumnBuilder;
|
|
16
|
+
foreignIdFor(tableName: string, columnName?: string): Knex.ColumnBuilder;
|
|
17
|
+
}
|
|
18
|
+
interface QueryBuilder<TRecord = any, TResult = any> {
|
|
19
|
+
where(...args: any[]): this;
|
|
20
|
+
orWhere(...args: any[]): this;
|
|
21
|
+
whereNot(...args: any[]): this;
|
|
22
|
+
whereNull(...args: any[]): this;
|
|
23
|
+
whereNotNull(...args: any[]): this;
|
|
24
|
+
whereIn(...args: any[]): this;
|
|
25
|
+
whereNotIn(...args: any[]): this;
|
|
26
|
+
whereBetween(...args: any[]): this;
|
|
27
|
+
whereNotBetween(...args: any[]): this;
|
|
28
|
+
whereExists(...args: any[]): this;
|
|
29
|
+
whereNotExists(...args: any[]): this;
|
|
30
|
+
join(...args: any[]): this;
|
|
31
|
+
leftJoin(...args: any[]): this;
|
|
32
|
+
rightJoin(...args: any[]): this;
|
|
33
|
+
innerJoin(...args: any[]): this;
|
|
34
|
+
select(...args: any[]): this;
|
|
35
|
+
distinct(...args: any[]): this;
|
|
36
|
+
orderBy(...args: any[]): this;
|
|
37
|
+
orderByRaw(...args: any[]): this;
|
|
38
|
+
limit(...args: any[]): this;
|
|
39
|
+
offset(...args: any[]): this;
|
|
40
|
+
groupBy(...args: any[]): this;
|
|
41
|
+
having(...args: any[]): this;
|
|
42
|
+
whereRaw(...args: any[]): this;
|
|
43
|
+
selectRaw(...args: any[]): this;
|
|
44
|
+
joinWith(type: "BELONGSTO" | "HASONE" | "HASMANY" | "BELONGSTOMANY", table: string, relation: {
|
|
45
|
+
localKey: string;
|
|
46
|
+
foreignKey: string;
|
|
47
|
+
} | {
|
|
48
|
+
pivotTable: string;
|
|
49
|
+
localKey: string;
|
|
50
|
+
pivotLocalKey: string;
|
|
51
|
+
pivotForeignKey: string;
|
|
52
|
+
foreignKey: string;
|
|
53
|
+
}, as: string, callback?: (qb: Knex.QueryBuilder) => void): Knex.QueryBuilder<TRecord, TResult>;
|
|
54
|
+
whereJoinHas(type: "BELONGSTO" | "HASONE" | "HASMANY" | "BELONGSTOMANY", table: string, relation: string | {
|
|
55
|
+
pivotTable: string;
|
|
56
|
+
localKey: string;
|
|
57
|
+
pivotLocalKey: string;
|
|
58
|
+
pivotForeignKey: string;
|
|
59
|
+
foreignKey: string;
|
|
60
|
+
}, foreignKey?: string, callback?: (qb: Knex.QueryBuilder) => void): Knex.QueryBuilder<TRecord, TResult>;
|
|
61
|
+
orWhereJoinHas(type: "BELONGSTO" | "HASONE" | "HASMANY" | "BELONGSTOMANY", table: string, relation: string | {
|
|
62
|
+
pivotTable: string;
|
|
63
|
+
localKey: string;
|
|
64
|
+
pivotLocalKey: string;
|
|
65
|
+
pivotForeignKey: string;
|
|
66
|
+
foreignKey: string;
|
|
67
|
+
}, foreignKey?: string, callback?: (qb: Knex.QueryBuilder) => void): Knex.QueryBuilder<TRecord, TResult>;
|
|
68
|
+
whereJoinDoesntHave(type: "BELONGSTO" | "HASONE" | "HASMANY" | "BELONGSTOMANY", table: string, relation: string | {
|
|
69
|
+
pivotTable: string;
|
|
70
|
+
localKey: string;
|
|
71
|
+
pivotLocalKey: string;
|
|
72
|
+
pivotForeignKey: string;
|
|
73
|
+
foreignKey: string;
|
|
74
|
+
}, foreignKey?: string, callback?: (qb: Knex.QueryBuilder) => void): Knex.QueryBuilder<TRecord, TResult>;
|
|
75
|
+
orWhereJoinDoesntHave(type: "BELONGSTO" | "HASONE" | "HASMANY" | "BELONGSTOMANY", table: string, relation: string | {
|
|
76
|
+
pivotTable: string;
|
|
77
|
+
localKey: string;
|
|
78
|
+
pivotLocalKey: string;
|
|
79
|
+
pivotForeignKey: string;
|
|
80
|
+
foreignKey: string;
|
|
81
|
+
}, foreignKey?: string, callback?: (qb: Knex.QueryBuilder) => void): Knex.QueryBuilder<TRecord, TResult>;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
package/dist/db.util.js
ADDED
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
import knex from 'knex';
|
|
2
|
+
import { conversion } from './conversion.util';
|
|
3
|
+
// ==============================
|
|
4
|
+
// ## Driver resolver
|
|
5
|
+
// ==============================
|
|
6
|
+
function resolveDriver(conn) {
|
|
7
|
+
if (!conn)
|
|
8
|
+
return 'pg';
|
|
9
|
+
const v = conn.toLowerCase();
|
|
10
|
+
if (['pg', 'pgsql', 'postgres'].includes(v))
|
|
11
|
+
return 'pg';
|
|
12
|
+
if (['mysql', 'mysql2'].includes(v))
|
|
13
|
+
return 'mysql2';
|
|
14
|
+
throw new Error(`Unsupported DB_CONNECTION: ${conn}`);
|
|
15
|
+
}
|
|
16
|
+
// ==============================
|
|
17
|
+
// ## Knex factory
|
|
18
|
+
// ==============================
|
|
19
|
+
function createKnex(config) {
|
|
20
|
+
const client = resolveDriver(config.client);
|
|
21
|
+
return knex({
|
|
22
|
+
client,
|
|
23
|
+
connection: {
|
|
24
|
+
host: config.host ?? '127.0.0.1',
|
|
25
|
+
port: config.port ?? (client === 'mysql2' ? 3306 : 5432),
|
|
26
|
+
user: config.user ?? 'postgres',
|
|
27
|
+
password: config.password ?? 'password',
|
|
28
|
+
database: config.database ?? 'db_elysia_light',
|
|
29
|
+
},
|
|
30
|
+
pool: { min: 2, max: 10 },
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
// ==============================
|
|
34
|
+
// ## Connection registry
|
|
35
|
+
// ==============================
|
|
36
|
+
const connections = {};
|
|
37
|
+
// ==============================
|
|
38
|
+
// ## Default connection
|
|
39
|
+
// ==============================
|
|
40
|
+
const DEFAULT_NAME = 'default';
|
|
41
|
+
connections[DEFAULT_NAME] = createKnex({
|
|
42
|
+
client: process.env.DB_CONNECTION,
|
|
43
|
+
host: process.env.DB_HOST,
|
|
44
|
+
port: Number(process.env.DB_PORT),
|
|
45
|
+
user: process.env.DB_USERNAME,
|
|
46
|
+
password: process.env.DB_PASSWORD,
|
|
47
|
+
database: process.env.DB_DATABASE,
|
|
48
|
+
});
|
|
49
|
+
// ==============================
|
|
50
|
+
// ## Export default db
|
|
51
|
+
// ==============================
|
|
52
|
+
export const db = connections[DEFAULT_NAME];
|
|
53
|
+
// ==============================
|
|
54
|
+
// ## Named connection (multiple DB)
|
|
55
|
+
// ==============================
|
|
56
|
+
export function useDB(name, config) {
|
|
57
|
+
if (!connections[name]) {
|
|
58
|
+
if (!config) {
|
|
59
|
+
throw new Error(`DB connection "${name}" not found`);
|
|
60
|
+
}
|
|
61
|
+
connections[name] = createKnex(config);
|
|
62
|
+
}
|
|
63
|
+
return connections[name];
|
|
64
|
+
}
|
|
65
|
+
// ==============================
|
|
66
|
+
// ## Close all connections (CLI safe)
|
|
67
|
+
// ==============================
|
|
68
|
+
export async function closeAllDB() {
|
|
69
|
+
await Promise.all(Object.values(connections).map(db => db.destroy()));
|
|
70
|
+
}
|
|
71
|
+
// ==============================
|
|
72
|
+
// ## Schema Builder Extensions
|
|
73
|
+
// ==============================
|
|
74
|
+
knex.TableBuilder.extend("softDelete", function () {
|
|
75
|
+
return this.timestamp("deleted_at").nullable();
|
|
76
|
+
});
|
|
77
|
+
knex.TableBuilder.extend("foreignIdFor", function (tableName, columnName) {
|
|
78
|
+
const col = columnName || `${conversion.strSingular(tableName)}_id`;
|
|
79
|
+
return this.bigInteger(col).unsigned().references("id").inTable(tableName);
|
|
80
|
+
});
|
|
81
|
+
function getBaseTable(qb) {
|
|
82
|
+
return qb._single?.table;
|
|
83
|
+
}
|
|
84
|
+
function buildWhereHas(qb, type, table, localKeyOrRelation, foreignKey, callback) {
|
|
85
|
+
const baseTable = getBaseTable(qb);
|
|
86
|
+
if (!baseTable) {
|
|
87
|
+
throw new Error("whereHas harus dipanggil setelah table()");
|
|
88
|
+
}
|
|
89
|
+
qb.select(1).from(table);
|
|
90
|
+
if (type != "BELONGSTOMANY") {
|
|
91
|
+
qb.whereRaw(`${foreignKey} = ${baseTable}.${localKeyOrRelation}`);
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
const r = localKeyOrRelation;
|
|
95
|
+
qb.join(r.pivotTable, `${r.pivotTable}.${r.pivotForeignKey}`, `${table}.${r.foreignKey}`).whereRaw(`${r.pivotTable}.${r.pivotLocalKey} = ${baseTable}.${r.localKey}`);
|
|
96
|
+
}
|
|
97
|
+
if (callback)
|
|
98
|
+
callback(qb);
|
|
99
|
+
}
|
|
100
|
+
knex.QueryBuilder.extend("joinWith", function (type, table, relation, as, callback) {
|
|
101
|
+
const baseTable = getBaseTable(this);
|
|
102
|
+
if (!baseTable)
|
|
103
|
+
throw new Error("joinWith() must be after table()");
|
|
104
|
+
let subquery = null;
|
|
105
|
+
if (type === "BELONGSTO") {
|
|
106
|
+
const r = relation;
|
|
107
|
+
subquery = `
|
|
108
|
+
(
|
|
109
|
+
select row_to_json(${table})
|
|
110
|
+
from ${table}
|
|
111
|
+
where ${table}.${r.foreignKey} = ${baseTable}.${r.localKey}
|
|
112
|
+
limit 1
|
|
113
|
+
)
|
|
114
|
+
`;
|
|
115
|
+
}
|
|
116
|
+
if (type === "HASONE") {
|
|
117
|
+
const r = relation;
|
|
118
|
+
subquery = `
|
|
119
|
+
(
|
|
120
|
+
select row_to_json(${table})
|
|
121
|
+
from ${table}
|
|
122
|
+
where ${table}.${r.foreignKey} = ${baseTable}.${r.localKey}
|
|
123
|
+
limit 1
|
|
124
|
+
)
|
|
125
|
+
`;
|
|
126
|
+
}
|
|
127
|
+
if (type === "HASMANY") {
|
|
128
|
+
const r = relation;
|
|
129
|
+
subquery = `
|
|
130
|
+
(
|
|
131
|
+
select coalesce(json_agg(${table}), '[]'::json)
|
|
132
|
+
from ${table}
|
|
133
|
+
where ${table}.${r.foreignKey} = ${baseTable}.${r.localKey}
|
|
134
|
+
)
|
|
135
|
+
`;
|
|
136
|
+
}
|
|
137
|
+
if (type === "BELONGSTOMANY") {
|
|
138
|
+
const r = relation;
|
|
139
|
+
subquery = `
|
|
140
|
+
(
|
|
141
|
+
select coalesce(json_agg(${table}), '[]'::json)
|
|
142
|
+
from ${table}
|
|
143
|
+
inner join ${r.pivotTable}
|
|
144
|
+
on ${r.pivotTable}.${r.pivotForeignKey} = ${table}.${r.foreignKey}
|
|
145
|
+
where ${r.pivotTable}.${r.pivotLocalKey} = ${baseTable}.${r.localKey}
|
|
146
|
+
)
|
|
147
|
+
`;
|
|
148
|
+
}
|
|
149
|
+
if (!subquery) {
|
|
150
|
+
throw new Error(`Unsupported relation type: ${type}`);
|
|
151
|
+
}
|
|
152
|
+
if (callback) {
|
|
153
|
+
callback(this);
|
|
154
|
+
}
|
|
155
|
+
return this.select(this.client.raw(`${subquery} as "${as}"`));
|
|
156
|
+
});
|
|
157
|
+
knex.QueryBuilder.extend("whereJoinHas", function (type, table, localKeyOrRelation, foreignKey, callback) {
|
|
158
|
+
return this.whereExists(function () {
|
|
159
|
+
buildWhereHas(this, type, table, localKeyOrRelation, foreignKey, callback);
|
|
160
|
+
});
|
|
161
|
+
});
|
|
162
|
+
knex.QueryBuilder.extend("orJoinWhereHas", function (type, table, localKeyOrRelation, foreignKey, callback) {
|
|
163
|
+
return this.orWhereExists(function () {
|
|
164
|
+
buildWhereHas(this, type, table, localKeyOrRelation, foreignKey, callback);
|
|
165
|
+
});
|
|
166
|
+
});
|
|
167
|
+
knex.QueryBuilder.extend("whereJoinDoesntHave", function (type, table, localKeyOrRelation, foreignKey, callback) {
|
|
168
|
+
return this.whereNotExists(function () {
|
|
169
|
+
buildWhereHas(this, type, table, localKeyOrRelation, foreignKey, callback);
|
|
170
|
+
});
|
|
171
|
+
});
|
|
172
|
+
knex.QueryBuilder.extend("orWhereJoinDoesntHave", function (type, table, localKeyOrRelation, foreignKey, callback) {
|
|
173
|
+
return this.orWhereNotExists(function () {
|
|
174
|
+
buildWhereHas(this, type, table, localKeyOrRelation, foreignKey, callback);
|
|
175
|
+
});
|
|
176
|
+
});
|
|
177
|
+
//# sourceMappingURL=db.util.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"db.util.js","sourceRoot":"","sources":["../src/db.util.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export * from "./auth";
|
|
2
|
+
export * from "./controller";
|
|
3
|
+
export * from "./conversion";
|
|
4
|
+
export * from "./context";
|
|
5
|
+
export * from "./middleware";
|
|
6
|
+
export * from "./permission";
|
|
7
|
+
export * from "./route";
|
|
8
|
+
export * from "./storage";
|
|
9
|
+
export * from "./validation";
|
|
10
|
+
export * from "./mail";
|
|
11
|
+
export * from "./logger";
|
|
12
|
+
export * from "./registry";
|
|
13
|
+
export * from "./commands/cli";
|
|
14
|
+
declare module "knex" {
|
|
15
|
+
namespace Knex {
|
|
16
|
+
interface CreateTableBuilder {
|
|
17
|
+
foreignIdFor(tableName: string, column?: string): Knex.ColumnBuilder;
|
|
18
|
+
softDelete(column?: string): Knex.ColumnBuilder;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export * from "./auth";
|
|
2
|
+
export * from "./controller";
|
|
3
|
+
export * from "./conversion";
|
|
4
|
+
export * from "./context";
|
|
5
|
+
export * from "./middleware";
|
|
6
|
+
export * from "./permission";
|
|
7
|
+
export * from "./route";
|
|
8
|
+
export * from "./storage";
|
|
9
|
+
export * from "./validation";
|
|
10
|
+
export * from "./mail";
|
|
11
|
+
export * from "./logger";
|
|
12
|
+
export * from "./registry";
|
|
13
|
+
export * from "./commands/cli";
|
|
14
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC;AACvB,cAAc,cAAc,CAAC;AAC7B,cAAc,cAAc,CAAC;AAC7B,cAAc,WAAW,CAAC;AAC1B,cAAc,cAAc,CAAC;AAC7B,cAAc,cAAc,CAAC;AAC7B,cAAc,SAAS,CAAC;AACxB,cAAc,WAAW,CAAC;AAC1B,cAAc,cAAc,CAAC;AAC7B,cAAc,QAAQ,CAAC;AACvB,cAAc,UAAU,CAAC;AACzB,cAAc,YAAY,CAAC;AAC3B,cAAc,gBAAgB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./logger";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/logger/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
export interface AccessLog {
|
|
2
|
+
method: string;
|
|
3
|
+
path: string;
|
|
4
|
+
status: number;
|
|
5
|
+
latency: number;
|
|
6
|
+
ip?: string | null;
|
|
7
|
+
agent?: string | null;
|
|
8
|
+
at?: string;
|
|
9
|
+
}
|
|
10
|
+
export interface ErrorLog {
|
|
11
|
+
service?: string;
|
|
12
|
+
key?: string;
|
|
13
|
+
feature?: string;
|
|
14
|
+
error: string | null;
|
|
15
|
+
reference?: string | null;
|
|
16
|
+
at?: string;
|
|
17
|
+
}
|
|
18
|
+
export declare const logger: {
|
|
19
|
+
start: (msg: string) => void;
|
|
20
|
+
info: (msg: string) => void;
|
|
21
|
+
warning: (msg: string) => void;
|
|
22
|
+
queue: (msg: string) => void;
|
|
23
|
+
cron: (msg: string) => void;
|
|
24
|
+
socket: (msg: string) => void;
|
|
25
|
+
access: (msg: AccessLog) => void;
|
|
26
|
+
error: (msg: string, payload?: ErrorLog) => void;
|
|
27
|
+
queueError: (msg: string, payload?: ErrorLog) => void;
|
|
28
|
+
cronError: (msg: string, payload?: ErrorLog) => void;
|
|
29
|
+
socketError: (msg: string, payload?: ErrorLog) => void;
|
|
30
|
+
};
|