zeti-framework 0.1.8 β 0.1.9
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/core/bootstrap.d.ts +14 -0
- package/dist/core/bootstrap.d.ts.map +1 -0
- package/dist/core/bootstrap.js +66 -0
- package/dist/core/bootstrap.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -1
- package/dist/scripts/run-prebuild.d.ts +1 -4
- package/dist/scripts/run-prebuild.d.ts.map +1 -1
- package/dist/scripts/run-prebuild.js +19 -9
- package/dist/scripts/run-prebuild.js.map +1 -1
- package/dist/utils/middleware.d.ts +6 -0
- package/dist/utils/middleware.d.ts.map +1 -0
- package/dist/utils/middleware.js +21 -0
- package/dist/utils/middleware.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { ZetiConfig } from '../types/config';
|
|
2
|
+
import { type ZetiApp } from './framework';
|
|
3
|
+
export interface StartZetiOptions<TPrisma = any, TUser = any> {
|
|
4
|
+
config: ZetiConfig;
|
|
5
|
+
prismaClient: new (...args: any[]) => TPrisma;
|
|
6
|
+
port?: number;
|
|
7
|
+
registryPath?: string;
|
|
8
|
+
onReady?: (app: ZetiApp<TPrisma, TUser>) => void | Promise<void>;
|
|
9
|
+
}
|
|
10
|
+
export declare function startZeti<TPrisma = any, TUser = any>(options: StartZetiOptions<TPrisma, TUser>): Promise<ZetiApp<TPrisma, TUser>>;
|
|
11
|
+
export declare function getPrismaClient<TPrisma = any>(tenantId?: string): TPrisma;
|
|
12
|
+
export declare function getSpecialDatabase<TPrisma = any>(key: string): TPrisma;
|
|
13
|
+
export declare function createAppProxy<TPrisma = any, TUser = any>(): ZetiApp<TPrisma, TUser>;
|
|
14
|
+
//# sourceMappingURL=bootstrap.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bootstrap.d.ts","sourceRoot":"","sources":["../../src/core/bootstrap.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAiC,KAAK,OAAO,EAAE,MAAM,aAAa,CAAC;AAE1E,MAAM,WAAW,gBAAgB,CAAC,OAAO,GAAG,GAAG,EAAE,KAAK,GAAG,GAAG;IAC1D,MAAM,EAAE,UAAU,CAAC;IACnB,YAAY,EAAE,KAAK,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,OAAO,CAAC;IAC9C,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,OAAO,CAAC,EAAE,CAAC,GAAG,EAAE,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAClE;AAID,wBAAsB,SAAS,CAAC,OAAO,GAAG,GAAG,EAAE,KAAK,GAAG,GAAG,EACxD,OAAO,EAAE,gBAAgB,CAAC,OAAO,EAAE,KAAK,CAAC,GACxC,OAAO,CAAC,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC,CAuClC;AAED,wBAAgB,eAAe,CAAC,OAAO,GAAG,GAAG,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,OAAO,CAgBzE;AAED,wBAAgB,kBAAkB,CAAC,OAAO,GAAG,GAAG,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAMtE;AAED,wBAAgB,cAAc,CAAC,OAAO,GAAG,GAAG,EAAE,KAAK,GAAG,GAAG,KAAK,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,CAUpF"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { serve } from '@hono/node-server';
|
|
2
|
+
import { initializeZetiApp, getZetiApp } from './framework';
|
|
3
|
+
let globalPrismaType = null;
|
|
4
|
+
export async function startZeti(options) {
|
|
5
|
+
const { config, prismaClient, port = 3334, registryPath, onReady } = options;
|
|
6
|
+
globalPrismaType = prismaClient;
|
|
7
|
+
const app = initializeZetiApp({
|
|
8
|
+
config,
|
|
9
|
+
prismaClient,
|
|
10
|
+
});
|
|
11
|
+
if (!app) {
|
|
12
|
+
throw new Error('Falha ao inicializar Zeti app');
|
|
13
|
+
}
|
|
14
|
+
const registryImportPath = registryPath || '../.zeti/registry';
|
|
15
|
+
try {
|
|
16
|
+
await import(registryImportPath);
|
|
17
|
+
}
|
|
18
|
+
catch (e) {
|
|
19
|
+
if (e.code !== 'ERR_MODULE_NOT_FOUND') {
|
|
20
|
+
throw e;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
app.honoApp.get('/health', (c) => c.json({ status: 'ok', timestamp: new Date().toISOString() }));
|
|
24
|
+
if (onReady) {
|
|
25
|
+
await onReady(app);
|
|
26
|
+
}
|
|
27
|
+
console.log(`π Zeti Backend running on http://localhost:${port}`);
|
|
28
|
+
serve({
|
|
29
|
+
fetch: app.honoApp.fetch,
|
|
30
|
+
port,
|
|
31
|
+
});
|
|
32
|
+
return app;
|
|
33
|
+
}
|
|
34
|
+
export function getPrismaClient(tenantId) {
|
|
35
|
+
const app = getZetiApp();
|
|
36
|
+
if (!app) {
|
|
37
|
+
throw new Error('Zeti app not initialized. getPrismaClient can only be called after startZeti.');
|
|
38
|
+
}
|
|
39
|
+
if (tenantId) {
|
|
40
|
+
return app.tenantManager.getTenantDatabase(tenantId);
|
|
41
|
+
}
|
|
42
|
+
const allDatabases = app.tenantManager.getAllDatabases();
|
|
43
|
+
if (allDatabases.length > 0) {
|
|
44
|
+
return app.tenantManager.getTenantDatabase(allDatabases[0]);
|
|
45
|
+
}
|
|
46
|
+
throw new Error('Nenhum banco de dados configurado');
|
|
47
|
+
}
|
|
48
|
+
export function getSpecialDatabase(key) {
|
|
49
|
+
const app = getZetiApp();
|
|
50
|
+
if (!app) {
|
|
51
|
+
throw new Error('Zeti app not initialized. getSpecialDatabase can only be called after startZeti.');
|
|
52
|
+
}
|
|
53
|
+
return app.tenantManager.getSpecialDatabase(key);
|
|
54
|
+
}
|
|
55
|
+
export function createAppProxy() {
|
|
56
|
+
return new Proxy({}, {
|
|
57
|
+
get(_target, prop) {
|
|
58
|
+
const app = getZetiApp();
|
|
59
|
+
if (!app) {
|
|
60
|
+
throw new Error('Zeti app nΓ£o inicializado. Use startZeti() primeiro.');
|
|
61
|
+
}
|
|
62
|
+
return app[prop];
|
|
63
|
+
},
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
//# sourceMappingURL=bootstrap.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bootstrap.js","sourceRoot":"","sources":["../../src/core/bootstrap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAE1C,OAAO,EAAE,iBAAiB,EAAE,UAAU,EAAgB,MAAM,aAAa,CAAC;AAU1E,IAAI,gBAAgB,GAAQ,IAAI,CAAC;AAEjC,MAAM,CAAC,KAAK,UAAU,SAAS,CAC7B,OAAyC;IAEzC,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,IAAI,GAAG,IAAI,EAAE,YAAY,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;IAE7E,gBAAgB,GAAG,YAAY,CAAC;IAEhC,MAAM,GAAG,GAAG,iBAAiB,CAAiB;QAC5C,MAAM;QACN,YAAY;KACb,CAAC,CAAC;IAEH,IAAI,CAAC,GAAG,EAAE,CAAC;QACT,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;IACnD,CAAC;IAED,MAAM,kBAAkB,GAAG,YAAY,IAAI,mBAAmB,CAAC;IAC/D,IAAI,CAAC;QACH,MAAM,MAAM,CAAC,kBAAkB,CAAC,CAAC;IACnC,CAAC;IAAC,OAAO,CAAM,EAAE,CAAC;QAChB,IAAI,CAAC,CAAC,IAAI,KAAK,sBAAsB,EAAE,CAAC;YACtC,MAAM,CAAC,CAAC;QACV,CAAC;IACH,CAAC;IAED,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,CAC/B,CAAC,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,EAAE,CAAC,CAC9D,CAAC;IAEF,IAAI,OAAO,EAAE,CAAC;QACZ,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC;IACrB,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,+CAA+C,IAAI,EAAE,CAAC,CAAC;IAEnE,KAAK,CAAC;QACJ,KAAK,EAAE,GAAG,CAAC,OAAO,CAAC,KAAK;QACxB,IAAI;KACL,CAAC,CAAC;IAEH,OAAO,GAAG,CAAC;AACb,CAAC;AAED,MAAM,UAAU,eAAe,CAAgB,QAAiB;IAC9D,MAAM,GAAG,GAAG,UAAU,EAAE,CAAC;IACzB,IAAI,CAAC,GAAG,EAAE,CAAC;QACT,MAAM,IAAI,KAAK,CAAC,+EAA+E,CAAC,CAAC;IACnG,CAAC;IAED,IAAI,QAAQ,EAAE,CAAC;QACb,OAAO,GAAG,CAAC,aAAa,CAAC,iBAAiB,CAAC,QAAQ,CAAY,CAAC;IAClE,CAAC;IAED,MAAM,YAAY,GAAG,GAAG,CAAC,aAAa,CAAC,eAAe,EAAE,CAAC;IACzD,IAAI,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC5B,OAAO,GAAG,CAAC,aAAa,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC,CAAC,CAAY,CAAC;IACzE,CAAC;IAED,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;AACvD,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAgB,GAAW;IAC3D,MAAM,GAAG,GAAG,UAAU,EAAE,CAAC;IACzB,IAAI,CAAC,GAAG,EAAE,CAAC;QACT,MAAM,IAAI,KAAK,CAAC,kFAAkF,CAAC,CAAC;IACtG,CAAC;IACD,OAAO,GAAG,CAAC,aAAa,CAAC,kBAAkB,CAAC,GAAG,CAAY,CAAC;AAC9D,CAAC;AAED,MAAM,UAAU,cAAc;IAC5B,OAAO,IAAI,KAAK,CAAC,EAA6B,EAAE;QAC9C,GAAG,CAAC,OAAO,EAAE,IAAI;YACf,MAAM,GAAG,GAAG,UAAU,EAAE,CAAC;YACzB,IAAI,CAAC,GAAG,EAAE,CAAC;gBACT,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;YAC1E,CAAC;YACD,OAAQ,GAAW,CAAC,IAAI,CAAC,CAAC;QAC5B,CAAC;KACF,CAAC,CAAC;AACL,CAAC"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
export * from './core/framework';
|
|
2
|
+
export * from './core/bootstrap';
|
|
2
3
|
export * from './types/config';
|
|
3
4
|
export * from './types/framework';
|
|
4
5
|
export * from './types/prisma';
|
|
@@ -10,8 +11,10 @@ export * from './utils/error-handler';
|
|
|
10
11
|
export * from './utils/password';
|
|
11
12
|
export * from './utils/jwt';
|
|
12
13
|
export * from './utils/http-exceptions';
|
|
14
|
+
export * from './utils/middleware';
|
|
13
15
|
export * from './scripts/generate-registry';
|
|
14
16
|
export * from './scripts/generate-swagger-types';
|
|
15
17
|
export { runPrebuild } from './scripts/run-prebuild';
|
|
16
18
|
export { initializeZetiApp, getZetiApp, getZetiAppTyped, honoRoutesZeti, autoInitializeZetiApp } from './core/framework';
|
|
19
|
+
export { startZeti, getPrismaClient, getSpecialDatabase, createAppProxy } from './core/bootstrap';
|
|
17
20
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,kBAAkB,CAAC;AACjC,cAAc,aAAa,CAAC;AAC5B,cAAc,yBAAyB,CAAC;AACxC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,kCAAkC,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,OAAO,EAAE,iBAAiB,EAAE,UAAU,EAAE,eAAe,EAAE,cAAc,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC;AACjC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,kBAAkB,CAAC;AACjC,cAAc,aAAa,CAAC;AAC5B,cAAc,yBAAyB,CAAC;AACxC,cAAc,oBAAoB,CAAC;AACnC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,kCAAkC,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,OAAO,EAAE,iBAAiB,EAAE,UAAU,EAAE,eAAe,EAAE,cAAc,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AACzH,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,kBAAkB,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
export * from './core/framework';
|
|
2
|
+
export * from './core/bootstrap';
|
|
2
3
|
export * from './types/config';
|
|
3
4
|
export * from './types/framework';
|
|
4
5
|
export * from './types/prisma';
|
|
@@ -10,8 +11,10 @@ export * from './utils/error-handler';
|
|
|
10
11
|
export * from './utils/password';
|
|
11
12
|
export * from './utils/jwt';
|
|
12
13
|
export * from './utils/http-exceptions';
|
|
14
|
+
export * from './utils/middleware';
|
|
13
15
|
export * from './scripts/generate-registry';
|
|
14
16
|
export * from './scripts/generate-swagger-types';
|
|
15
17
|
export { runPrebuild } from './scripts/run-prebuild';
|
|
16
18
|
export { initializeZetiApp, getZetiApp, getZetiAppTyped, honoRoutesZeti, autoInitializeZetiApp } from './core/framework';
|
|
19
|
+
export { startZeti, getPrismaClient, getSpecialDatabase, createAppProxy } from './core/bootstrap';
|
|
17
20
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,kBAAkB,CAAC;AACjC,cAAc,aAAa,CAAC;AAC5B,cAAc,yBAAyB,CAAC;AACxC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,kCAAkC,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,OAAO,EAAE,iBAAiB,EAAE,UAAU,EAAE,eAAe,EAAE,cAAc,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC;AACjC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,kBAAkB,CAAC;AACjC,cAAc,aAAa,CAAC;AAC5B,cAAc,yBAAyB,CAAC;AACxC,cAAc,oBAAoB,CAAC;AACnC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,kCAAkC,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,OAAO,EAAE,iBAAiB,EAAE,UAAU,EAAE,eAAe,EAAE,cAAc,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AACzH,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,kBAAkB,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC"}
|
|
@@ -5,10 +5,7 @@ export interface RunPrebuildOptions {
|
|
|
5
5
|
controllersPath?: string;
|
|
6
6
|
registryPath?: string;
|
|
7
7
|
swaggerOutputPath?: string;
|
|
8
|
+
prismaImport?: string;
|
|
8
9
|
}
|
|
9
|
-
/**
|
|
10
|
-
* Executa o prebuild: gera .zeti/registry.ts e .zeti/generated/swagger-schemas.ts.
|
|
11
|
-
* Deve ser chamado a partir da raiz do projeto (ex: .zeti/prebuild.ts).
|
|
12
|
-
*/
|
|
13
10
|
export declare function runPrebuild(options?: RunPrebuildOptions): Promise<void>;
|
|
14
11
|
//# sourceMappingURL=run-prebuild.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"run-prebuild.d.ts","sourceRoot":"","sources":["../../src/scripts/run-prebuild.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAElD,MAAM,WAAW,kBAAkB;IACjC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,iBAAiB,CAAC,EAAE,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"run-prebuild.d.ts","sourceRoot":"","sources":["../../src/scripts/run-prebuild.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAElD,MAAM,WAAW,kBAAkB;IACjC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAcD,wBAAsB,WAAW,CAAC,OAAO,GAAE,kBAAuB,GAAG,OAAO,CAAC,IAAI,CAAC,CAqDjF"}
|
|
@@ -3,10 +3,16 @@ import fs from 'fs';
|
|
|
3
3
|
import { pathToFileURL } from 'url';
|
|
4
4
|
import { generateRegistry } from './generate-registry';
|
|
5
5
|
import { generateSwaggerTypes } from './generate-swagger-types';
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
6
|
+
function generateAppFile(zetiDir, prismaImport) {
|
|
7
|
+
const appContent = `import { createAppProxy } from 'zeti-framework';
|
|
8
|
+
import type { PrismaClient } from '${prismaImport}';
|
|
9
|
+
|
|
10
|
+
export const app = createAppProxy<PrismaClient, any>();
|
|
11
|
+
|
|
12
|
+
export const { get, post, put, del, patch } = app;
|
|
13
|
+
`;
|
|
14
|
+
fs.writeFileSync(path.join(zetiDir, 'app.ts'), appContent);
|
|
15
|
+
}
|
|
10
16
|
export async function runPrebuild(options = {}) {
|
|
11
17
|
const projectRoot = path.resolve(options.projectRoot || process.cwd());
|
|
12
18
|
let zetiConfig = options.zetiConfig;
|
|
@@ -19,21 +25,22 @@ export async function runPrebuild(options = {}) {
|
|
|
19
25
|
}
|
|
20
26
|
}
|
|
21
27
|
catch {
|
|
22
|
-
// zeti.config pode ser .ts e falhar em Node puro; o caller pode passar zetiConfig
|
|
23
28
|
}
|
|
24
29
|
}
|
|
25
30
|
const controllersPath = path.join(projectRoot, options.controllersPath || 'src/controllers');
|
|
26
|
-
const
|
|
31
|
+
const zetiDir = path.join(projectRoot, '.zeti');
|
|
32
|
+
const registryPath = path.join(zetiDir, 'registry.ts');
|
|
27
33
|
const swaggerOutputPath = options.swaggerOutputPath ||
|
|
28
34
|
(zetiConfig?.swagger?.outputPath
|
|
29
35
|
? path.isAbsolute(zetiConfig.swagger.outputPath)
|
|
30
36
|
? zetiConfig.swagger.outputPath
|
|
31
37
|
: path.join(projectRoot, zetiConfig.swagger.outputPath)
|
|
32
|
-
: path.join(
|
|
38
|
+
: path.join(zetiDir, 'generated/swagger-schemas.ts'));
|
|
33
39
|
const generatedDir = path.dirname(swaggerOutputPath);
|
|
34
40
|
fs.mkdirSync(generatedDir, { recursive: true });
|
|
35
|
-
fs.mkdirSync(
|
|
36
|
-
console.log('π [zeti] Generating
|
|
41
|
+
fs.mkdirSync(zetiDir, { recursive: true });
|
|
42
|
+
console.log('π [zeti] Generating files...');
|
|
43
|
+
generateAppFile(zetiDir, options.prismaImport || '@prisma/client');
|
|
37
44
|
await Promise.all([
|
|
38
45
|
generateRegistry({
|
|
39
46
|
controllersPath,
|
|
@@ -46,5 +53,8 @@ export async function runPrebuild(options = {}) {
|
|
|
46
53
|
}),
|
|
47
54
|
]);
|
|
48
55
|
console.log('β
[zeti] Prebuild complete!');
|
|
56
|
+
console.log(' π .zeti/app.ts');
|
|
57
|
+
console.log(' π .zeti/registry.ts');
|
|
58
|
+
console.log(' π .zeti/generated/swagger-schemas.ts');
|
|
49
59
|
}
|
|
50
60
|
//# sourceMappingURL=run-prebuild.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"run-prebuild.js","sourceRoot":"","sources":["../../src/scripts/run-prebuild.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,EAAE,aAAa,EAAE,MAAM,KAAK,CAAC;AACpC,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;
|
|
1
|
+
{"version":3,"file":"run-prebuild.js","sourceRoot":"","sources":["../../src/scripts/run-prebuild.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { Context, Next } from 'hono';
|
|
2
|
+
export type MiddlewareHandler = (c: Context, next: Next) => Promise<void | Response>;
|
|
3
|
+
export declare function createMiddleware(handler: MiddlewareHandler): MiddlewareHandler;
|
|
4
|
+
export type MiddlewareFactory<T extends any[]> = (...args: T) => MiddlewareHandler;
|
|
5
|
+
export declare function createMiddlewareFactory<T extends any[]>(factory: (...args: T) => MiddlewareHandler): MiddlewareFactory<T>;
|
|
6
|
+
//# sourceMappingURL=middleware.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"middleware.d.ts","sourceRoot":"","sources":["../../src/utils/middleware.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAE1C,MAAM,MAAM,iBAAiB,GAAG,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,KAAK,OAAO,CAAC,IAAI,GAAG,QAAQ,CAAC,CAAC;AAErF,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,iBAAiB,GAAG,iBAAiB,CAmB9E;AAED,MAAM,MAAM,iBAAiB,CAAC,CAAC,SAAS,GAAG,EAAE,IAAI,CAAC,GAAG,IAAI,EAAE,CAAC,KAAK,iBAAiB,CAAC;AAEnF,wBAAgB,uBAAuB,CAAC,CAAC,SAAS,GAAG,EAAE,EACrD,OAAO,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,KAAK,iBAAiB,GACzC,iBAAiB,CAAC,CAAC,CAAC,CAEtB"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export function createMiddleware(handler) {
|
|
2
|
+
return async (c, next) => {
|
|
3
|
+
if (!c || !c.req || !next || typeof next !== 'function') {
|
|
4
|
+
if (next && typeof next === 'function') {
|
|
5
|
+
await next();
|
|
6
|
+
}
|
|
7
|
+
return;
|
|
8
|
+
}
|
|
9
|
+
const method = c.req?.method;
|
|
10
|
+
const url = c.req?.url;
|
|
11
|
+
if (!method || !url || url === '') {
|
|
12
|
+
await next();
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
return handler(c, next);
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
export function createMiddlewareFactory(factory) {
|
|
19
|
+
return (...args) => createMiddleware(factory(...args));
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../src/utils/middleware.ts"],"names":[],"mappings":"AAIA,MAAM,UAAU,gBAAgB,CAAC,OAA0B;IACzD,OAAO,KAAK,EAAE,CAAU,EAAE,IAAU,EAAE,EAAE;QACtC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,IAAI,OAAO,IAAI,KAAK,UAAU,EAAE,CAAC;YACxD,IAAI,IAAI,IAAI,OAAO,IAAI,KAAK,UAAU,EAAE,CAAC;gBACvC,MAAM,IAAI,EAAE,CAAC;YACf,CAAC;YACD,OAAO;QACT,CAAC;QAED,MAAM,MAAM,GAAG,CAAC,CAAC,GAAG,EAAE,MAAM,CAAC;QAC7B,MAAM,GAAG,GAAG,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QAEvB,IAAI,CAAC,MAAM,IAAI,CAAC,GAAG,IAAI,GAAG,KAAK,EAAE,EAAE,CAAC;YAClC,MAAM,IAAI,EAAE,CAAC;YACb,OAAO;QACT,CAAC;QAED,OAAO,OAAO,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;IAC1B,CAAC,CAAC;AACJ,CAAC;AAID,MAAM,UAAU,uBAAuB,CACrC,OAA0C;IAE1C,OAAO,CAAC,GAAG,IAAO,EAAE,EAAE,CAAC,gBAAgB,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;AAC5D,CAAC"}
|