@objectstack/nestjs 1.0.4 → 1.0.6
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/.turbo/turbo-build.log +24 -0
- package/CHANGELOG.md +19 -0
- package/dist/index.d.mts +54 -0
- package/dist/index.d.ts +9 -7
- package/dist/index.js +212 -221
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +205 -0
- package/dist/index.mjs.map +1 -0
- package/package.json +4 -4
- package/dist/index.d.ts.map +0 -1
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
|
|
2
|
+
> @objectstack/nestjs@1.0.6 build /home/runner/work/spec/spec/packages/adapters/nestjs
|
|
3
|
+
> tsup --config ../../../tsup.config.ts
|
|
4
|
+
|
|
5
|
+
[34mCLI[39m Building entry: src/index.ts
|
|
6
|
+
[34mCLI[39m Using tsconfig: tsconfig.json
|
|
7
|
+
[34mCLI[39m tsup v8.5.1
|
|
8
|
+
[34mCLI[39m Using tsup config: /home/runner/work/spec/spec/tsup.config.ts
|
|
9
|
+
[34mCLI[39m Target: es2020
|
|
10
|
+
[34mCLI[39m Cleaning output folder
|
|
11
|
+
[34mESM[39m Build start
|
|
12
|
+
[34mCJS[39m Build start
|
|
13
|
+
[33mESM[39m [33mYou have emitDecoratorMetadata enabled but @swc/core was not installed, skipping swc plugin[39m
|
|
14
|
+
[33mCJS[39m [33mYou have emitDecoratorMetadata enabled but @swc/core was not installed, skipping swc plugin[39m
|
|
15
|
+
[32mCJS[39m [1mdist/index.js [22m[32m8.05 KB[39m
|
|
16
|
+
[32mCJS[39m [1mdist/index.js.map [22m[32m10.75 KB[39m
|
|
17
|
+
[32mCJS[39m ⚡️ Build success in 47ms
|
|
18
|
+
[32mESM[39m [1mdist/index.mjs [22m[32m6.54 KB[39m
|
|
19
|
+
[32mESM[39m [1mdist/index.mjs.map [22m[32m10.73 KB[39m
|
|
20
|
+
[32mESM[39m ⚡️ Build success in 50ms
|
|
21
|
+
[34mDTS[39m Build start
|
|
22
|
+
[32mDTS[39m ⚡️ Build success in 9339ms
|
|
23
|
+
[32mDTS[39m [1mdist/index.d.mts [22m[32m1.74 KB[39m
|
|
24
|
+
[32mDTS[39m [1mdist/index.d.ts [22m[32m1.74 KB[39m
|
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,24 @@
|
|
|
1
1
|
# @objectstack/nestjs
|
|
2
2
|
|
|
3
|
+
## 1.0.6
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- @objectstack/runtime@1.0.6
|
|
8
|
+
|
|
9
|
+
## 1.0.5
|
|
10
|
+
|
|
11
|
+
### Patch Changes
|
|
12
|
+
|
|
13
|
+
- b1d24bd: refactor: migrate build system from tsc to tsup for faster builds
|
|
14
|
+
- Replaced `tsc` with `tsup` (using esbuild) across all packages
|
|
15
|
+
- Added shared `tsup.config.ts` in workspace root
|
|
16
|
+
- Added `tsup` as workspace dev dependency
|
|
17
|
+
- significantly improved build performance
|
|
18
|
+
- Updated dependencies [b1d24bd]
|
|
19
|
+
- Updated dependencies [877b864]
|
|
20
|
+
- @objectstack/runtime@1.0.5
|
|
21
|
+
|
|
3
22
|
## 1.0.4
|
|
4
23
|
|
|
5
24
|
### Patch Changes
|
package/dist/index.d.mts
ADDED
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { DynamicModule } from '@nestjs/common';
|
|
2
|
+
import { HttpDispatcher, ObjectKernel } from '@objectstack/runtime';
|
|
3
|
+
|
|
4
|
+
declare const OBJECT_KERNEL = "OBJECT_KERNEL";
|
|
5
|
+
declare const ConnectReq: (...dataOrPipes: unknown[]) => ParameterDecorator;
|
|
6
|
+
declare class ObjectStackService {
|
|
7
|
+
private readonly kernel;
|
|
8
|
+
dispatcher: HttpDispatcher;
|
|
9
|
+
constructor(kernel: ObjectKernel);
|
|
10
|
+
getKernel(): ObjectKernel;
|
|
11
|
+
}
|
|
12
|
+
declare class ObjectStackController {
|
|
13
|
+
private readonly service;
|
|
14
|
+
constructor(service: ObjectStackService);
|
|
15
|
+
private normalizeResponse;
|
|
16
|
+
private handleError;
|
|
17
|
+
discovery(): {
|
|
18
|
+
name: string;
|
|
19
|
+
version: string;
|
|
20
|
+
environment: string | undefined;
|
|
21
|
+
routes: {
|
|
22
|
+
data: string;
|
|
23
|
+
metadata: string;
|
|
24
|
+
auth: string;
|
|
25
|
+
graphql: string | undefined;
|
|
26
|
+
storage: string | undefined;
|
|
27
|
+
analytics: string | undefined;
|
|
28
|
+
hub: string | undefined;
|
|
29
|
+
};
|
|
30
|
+
features: {
|
|
31
|
+
graphql: boolean;
|
|
32
|
+
search: boolean;
|
|
33
|
+
websockets: boolean;
|
|
34
|
+
files: boolean;
|
|
35
|
+
analytics: boolean;
|
|
36
|
+
hub: boolean;
|
|
37
|
+
};
|
|
38
|
+
locale: {
|
|
39
|
+
default: string;
|
|
40
|
+
supported: string[];
|
|
41
|
+
timezone: string;
|
|
42
|
+
};
|
|
43
|
+
};
|
|
44
|
+
graphql(body: any, req: any, res: any): Promise<any>;
|
|
45
|
+
auth(req: any, res: any, body: any): Promise<any>;
|
|
46
|
+
metadata(req: any, res: any, body?: any): Promise<any>;
|
|
47
|
+
data(req: any, res: any, body: any, query: any): Promise<any>;
|
|
48
|
+
storage(req: any, res: any): Promise<any>;
|
|
49
|
+
}
|
|
50
|
+
declare class ObjectStackModule {
|
|
51
|
+
static forRoot(kernel: ObjectKernel): DynamicModule;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
export { ConnectReq, OBJECT_KERNEL, ObjectStackController, ObjectStackModule, ObjectStackService };
|
package/dist/index.d.ts
CHANGED
|
@@ -1,14 +1,15 @@
|
|
|
1
1
|
import { DynamicModule } from '@nestjs/common';
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
2
|
+
import { HttpDispatcher, ObjectKernel } from '@objectstack/runtime';
|
|
3
|
+
|
|
4
|
+
declare const OBJECT_KERNEL = "OBJECT_KERNEL";
|
|
5
|
+
declare const ConnectReq: (...dataOrPipes: unknown[]) => ParameterDecorator;
|
|
6
|
+
declare class ObjectStackService {
|
|
6
7
|
private readonly kernel;
|
|
7
8
|
dispatcher: HttpDispatcher;
|
|
8
9
|
constructor(kernel: ObjectKernel);
|
|
9
10
|
getKernel(): ObjectKernel;
|
|
10
11
|
}
|
|
11
|
-
|
|
12
|
+
declare class ObjectStackController {
|
|
12
13
|
private readonly service;
|
|
13
14
|
constructor(service: ObjectStackService);
|
|
14
15
|
private normalizeResponse;
|
|
@@ -46,7 +47,8 @@ export declare class ObjectStackController {
|
|
|
46
47
|
data(req: any, res: any, body: any, query: any): Promise<any>;
|
|
47
48
|
storage(req: any, res: any): Promise<any>;
|
|
48
49
|
}
|
|
49
|
-
|
|
50
|
+
declare class ObjectStackModule {
|
|
50
51
|
static forRoot(kernel: ObjectKernel): DynamicModule;
|
|
51
52
|
}
|
|
52
|
-
|
|
53
|
+
|
|
54
|
+
export { ConnectReq, OBJECT_KERNEL, ObjectStackController, ObjectStackModule, ObjectStackService };
|
package/dist/index.js
CHANGED
|
@@ -1,240 +1,231 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
7
9
|
};
|
|
8
|
-
var
|
|
9
|
-
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
10
17
|
};
|
|
11
|
-
var
|
|
12
|
-
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var __decorateClass = (decorators, target, key, kind) => {
|
|
20
|
+
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
|
|
21
|
+
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
|
22
|
+
if (decorator = decorators[i])
|
|
23
|
+
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
|
24
|
+
if (kind && result) __defProp(target, key, result);
|
|
25
|
+
return result;
|
|
13
26
|
};
|
|
14
|
-
var
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
27
|
+
var __decorateParam = (index, decorator) => (target, key) => decorator(target, key, index);
|
|
28
|
+
|
|
29
|
+
// src/index.ts
|
|
30
|
+
var index_exports = {};
|
|
31
|
+
__export(index_exports, {
|
|
32
|
+
ConnectReq: () => ConnectReq,
|
|
33
|
+
OBJECT_KERNEL: () => OBJECT_KERNEL,
|
|
34
|
+
ObjectStackController: () => ObjectStackController,
|
|
35
|
+
ObjectStackModule: () => ObjectStackModule,
|
|
36
|
+
ObjectStackService: () => ObjectStackService
|
|
23
37
|
});
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
38
|
+
module.exports = __toCommonJS(index_exports);
|
|
39
|
+
var import_common = require("@nestjs/common");
|
|
40
|
+
var import_common2 = require("@nestjs/common");
|
|
41
|
+
var import_runtime = require("@objectstack/runtime");
|
|
42
|
+
var OBJECT_KERNEL = "OBJECT_KERNEL";
|
|
43
|
+
var ConnectReq = (0, import_common.createParamDecorator)(
|
|
44
|
+
(_data, ctx) => {
|
|
45
|
+
return ctx.switchToHttp().getRequest();
|
|
46
|
+
}
|
|
47
|
+
);
|
|
48
|
+
var ObjectStackService = class {
|
|
49
|
+
constructor(kernel) {
|
|
50
|
+
this.kernel = kernel;
|
|
51
|
+
this.dispatcher = new import_runtime.HttpDispatcher(kernel);
|
|
52
|
+
}
|
|
53
|
+
getKernel() {
|
|
54
|
+
return this.kernel;
|
|
55
|
+
}
|
|
33
56
|
};
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
__param(0, (0, common_1.Inject)(exports.OBJECT_KERNEL)),
|
|
38
|
-
__metadata("design:paramtypes", [runtime_1.ObjectKernel])
|
|
57
|
+
ObjectStackService = __decorateClass([
|
|
58
|
+
(0, import_common2.Injectable)(),
|
|
59
|
+
__decorateParam(0, (0, import_common.Inject)(OBJECT_KERNEL))
|
|
39
60
|
], ObjectStackService);
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
Object.entries(result.response.headers).forEach(([k, v]) => res.setHeader(k, v));
|
|
51
|
-
}
|
|
52
|
-
return res.json(result.response.body);
|
|
53
|
-
}
|
|
54
|
-
if (result.result) {
|
|
55
|
-
const response = result.result;
|
|
56
|
-
// Handle redirect
|
|
57
|
-
if (response.type === 'redirect' && response.url) {
|
|
58
|
-
return res.redirect(response.url);
|
|
59
|
-
}
|
|
60
|
-
// Handle stream
|
|
61
|
-
if (response.type === 'stream' && response.stream) {
|
|
62
|
-
if (response.headers) {
|
|
63
|
-
Object.entries(response.headers).forEach(([k, v]) => res.setHeader(k, v));
|
|
64
|
-
}
|
|
65
|
-
response.stream.pipe(res);
|
|
66
|
-
return;
|
|
67
|
-
}
|
|
68
|
-
// If response is a standard Response object
|
|
69
|
-
if (response && typeof response.status === 'number' && typeof response.text === 'function') {
|
|
70
|
-
res.status(response.status);
|
|
71
|
-
if (response.headers && typeof response.headers.forEach === 'function') {
|
|
72
|
-
response.headers.forEach((v, k) => res.setHeader(k, v));
|
|
73
|
-
}
|
|
74
|
-
const text = await response.text();
|
|
75
|
-
res.send(text);
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
return res.status(200).json(response);
|
|
79
|
-
}
|
|
61
|
+
var ObjectStackController = class {
|
|
62
|
+
constructor(service) {
|
|
63
|
+
this.service = service;
|
|
64
|
+
}
|
|
65
|
+
async normalizeResponse(result, res) {
|
|
66
|
+
if (result.handled) {
|
|
67
|
+
if (result.response) {
|
|
68
|
+
res.status(result.response.status);
|
|
69
|
+
if (result.response.headers) {
|
|
70
|
+
Object.entries(result.response.headers).forEach(([k, v]) => res.setHeader(k, v));
|
|
80
71
|
}
|
|
81
|
-
return res.
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
message: err.message || 'Internal Server Error',
|
|
88
|
-
code: err.statusCode || 500,
|
|
89
|
-
details: err.details
|
|
90
|
-
}
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
// --- Discovery Endpoint ---
|
|
94
|
-
discovery() {
|
|
95
|
-
return this.service.dispatcher.getDiscoveryInfo('/api');
|
|
96
|
-
}
|
|
97
|
-
async graphql(body, req, res) {
|
|
98
|
-
try {
|
|
99
|
-
const result = await this.service.dispatcher.handleGraphQL(body, { request: req });
|
|
100
|
-
return res.json(result);
|
|
72
|
+
return res.json(result.response.body);
|
|
73
|
+
}
|
|
74
|
+
if (result.result) {
|
|
75
|
+
const response = result.result;
|
|
76
|
+
if (response.type === "redirect" && response.url) {
|
|
77
|
+
return res.redirect(response.url);
|
|
101
78
|
}
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
try {
|
|
109
|
-
const path = req.params[0] || req.url.split('/auth/')[1]?.split('?')[0] || '';
|
|
110
|
-
const result = await this.service.dispatcher.handleAuth(path, req.method, body, { request: req, response: res });
|
|
111
|
-
return this.normalizeResponse(result, res);
|
|
79
|
+
if (response.type === "stream" && response.stream) {
|
|
80
|
+
if (response.headers) {
|
|
81
|
+
Object.entries(response.headers).forEach(([k, v]) => res.setHeader(k, v));
|
|
82
|
+
}
|
|
83
|
+
response.stream.pipe(res);
|
|
84
|
+
return;
|
|
112
85
|
}
|
|
113
|
-
|
|
114
|
-
|
|
86
|
+
if (response && typeof response.status === "number" && typeof response.text === "function") {
|
|
87
|
+
res.status(response.status);
|
|
88
|
+
if (response.headers && typeof response.headers.forEach === "function") {
|
|
89
|
+
response.headers.forEach((v, k) => res.setHeader(k, v));
|
|
90
|
+
}
|
|
91
|
+
const text = await response.text();
|
|
92
|
+
res.send(text);
|
|
93
|
+
return;
|
|
115
94
|
}
|
|
95
|
+
return res.status(200).json(response);
|
|
96
|
+
}
|
|
116
97
|
}
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
98
|
+
return res.status(404).json({ success: false, error: { message: "Not Found", code: 404 } });
|
|
99
|
+
}
|
|
100
|
+
async handleError(err, res) {
|
|
101
|
+
return res.status(err.statusCode || 500).json({
|
|
102
|
+
success: false,
|
|
103
|
+
error: {
|
|
104
|
+
message: err.message || "Internal Server Error",
|
|
105
|
+
code: err.statusCode || 500,
|
|
106
|
+
details: err.details
|
|
107
|
+
}
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
discovery() {
|
|
111
|
+
return this.service.dispatcher.getDiscoveryInfo("/api");
|
|
112
|
+
}
|
|
113
|
+
async graphql(body, req, res) {
|
|
114
|
+
try {
|
|
115
|
+
const result = await this.service.dispatcher.handleGraphQL(body, { request: req });
|
|
116
|
+
return res.json(result);
|
|
117
|
+
} catch (err) {
|
|
118
|
+
return this.handleError(err, res);
|
|
133
119
|
}
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
return this.normalizeResponse(result, res);
|
|
143
|
-
}
|
|
144
|
-
catch (err) {
|
|
145
|
-
return this.handleError(err, res);
|
|
146
|
-
}
|
|
120
|
+
}
|
|
121
|
+
async auth(req, res, body) {
|
|
122
|
+
try {
|
|
123
|
+
const path = req.params[0] || req.url.split("/auth/")[1]?.split("?")[0] || "";
|
|
124
|
+
const result = await this.service.dispatcher.handleAuth(path, req.method, body, { request: req, response: res });
|
|
125
|
+
return this.normalizeResponse(result, res);
|
|
126
|
+
} catch (err) {
|
|
127
|
+
return this.handleError(err, res);
|
|
147
128
|
}
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
129
|
+
}
|
|
130
|
+
async metadata(req, res, body) {
|
|
131
|
+
try {
|
|
132
|
+
let path = req.params[0] || "";
|
|
133
|
+
if (req.url.includes("/metadata")) {
|
|
134
|
+
path = req.url.split("/metadata")[1].split("?")[0];
|
|
135
|
+
}
|
|
136
|
+
const payload = body || req.body;
|
|
137
|
+
const result = await this.service.dispatcher.handleMetadata(path, { request: req }, req.method, payload);
|
|
138
|
+
return this.normalizeResponse(result, res);
|
|
139
|
+
} catch (err) {
|
|
140
|
+
return this.handleError(err, res);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
async data(req, res, body, query) {
|
|
144
|
+
try {
|
|
145
|
+
let path = req.params[0] || "";
|
|
146
|
+
if (req.url.includes("/data")) {
|
|
147
|
+
path = req.url.substring(req.url.indexOf("/data") + 5).split("?")[0];
|
|
148
|
+
}
|
|
149
|
+
const result = await this.service.dispatcher.handleData(path, req.method, body, query, { request: req });
|
|
150
|
+
return this.normalizeResponse(result, res);
|
|
151
|
+
} catch (err) {
|
|
152
|
+
return this.handleError(err, res);
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
async storage(req, res) {
|
|
156
|
+
try {
|
|
157
|
+
let path = req.params[0] || "";
|
|
158
|
+
if (req.url.includes("/storage")) {
|
|
159
|
+
path = req.url.substring(req.url.indexOf("/storage") + 8).split("?")[0];
|
|
160
|
+
}
|
|
161
|
+
const file = req.file || req.files?.file;
|
|
162
|
+
const result = await this.service.dispatcher.handleStorage(path, req.method, file, { request: req });
|
|
163
|
+
return this.normalizeResponse(result, res);
|
|
164
|
+
} catch (err) {
|
|
165
|
+
return this.handleError(err, res);
|
|
163
166
|
}
|
|
167
|
+
}
|
|
164
168
|
};
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
(0, common_1.All)('data*'),
|
|
201
|
-
__param(0, (0, common_1.Req)()),
|
|
202
|
-
__param(1, (0, common_1.Res)()),
|
|
203
|
-
__param(2, (0, common_1.Body)()),
|
|
204
|
-
__param(3, (0, common_1.Query)()),
|
|
205
|
-
__metadata("design:type", Function),
|
|
206
|
-
__metadata("design:paramtypes", [Object, Object, Object, Object]),
|
|
207
|
-
__metadata("design:returntype", Promise)
|
|
208
|
-
], ObjectStackController.prototype, "data", null);
|
|
209
|
-
__decorate([
|
|
210
|
-
(0, common_1.All)('storage*'),
|
|
211
|
-
__param(0, (0, common_1.Req)()),
|
|
212
|
-
__param(1, (0, common_1.Res)()),
|
|
213
|
-
__metadata("design:type", Function),
|
|
214
|
-
__metadata("design:paramtypes", [Object, Object]),
|
|
215
|
-
__metadata("design:returntype", Promise)
|
|
216
|
-
], ObjectStackController.prototype, "storage", null);
|
|
217
|
-
exports.ObjectStackController = ObjectStackController = __decorate([
|
|
218
|
-
(0, common_1.Controller)('api'),
|
|
219
|
-
__metadata("design:paramtypes", [ObjectStackService])
|
|
169
|
+
__decorateClass([
|
|
170
|
+
(0, import_common.Get)()
|
|
171
|
+
], ObjectStackController.prototype, "discovery", 1);
|
|
172
|
+
__decorateClass([
|
|
173
|
+
(0, import_common.Post)("graphql"),
|
|
174
|
+
__decorateParam(0, (0, import_common.Body)()),
|
|
175
|
+
__decorateParam(1, (0, import_common.Req)()),
|
|
176
|
+
__decorateParam(2, (0, import_common.Res)())
|
|
177
|
+
], ObjectStackController.prototype, "graphql", 1);
|
|
178
|
+
__decorateClass([
|
|
179
|
+
(0, import_common.All)("auth/*"),
|
|
180
|
+
__decorateParam(0, (0, import_common.Req)()),
|
|
181
|
+
__decorateParam(1, (0, import_common.Res)()),
|
|
182
|
+
__decorateParam(2, (0, import_common.Body)())
|
|
183
|
+
], ObjectStackController.prototype, "auth", 1);
|
|
184
|
+
__decorateClass([
|
|
185
|
+
(0, import_common.All)("metadata*"),
|
|
186
|
+
__decorateParam(0, (0, import_common.Req)()),
|
|
187
|
+
__decorateParam(1, (0, import_common.Res)()),
|
|
188
|
+
__decorateParam(2, (0, import_common.Body)())
|
|
189
|
+
], ObjectStackController.prototype, "metadata", 1);
|
|
190
|
+
__decorateClass([
|
|
191
|
+
(0, import_common.All)("data*"),
|
|
192
|
+
__decorateParam(0, (0, import_common.Req)()),
|
|
193
|
+
__decorateParam(1, (0, import_common.Res)()),
|
|
194
|
+
__decorateParam(2, (0, import_common.Body)()),
|
|
195
|
+
__decorateParam(3, (0, import_common.Query)())
|
|
196
|
+
], ObjectStackController.prototype, "data", 1);
|
|
197
|
+
__decorateClass([
|
|
198
|
+
(0, import_common.All)("storage*"),
|
|
199
|
+
__decorateParam(0, (0, import_common.Req)()),
|
|
200
|
+
__decorateParam(1, (0, import_common.Res)())
|
|
201
|
+
], ObjectStackController.prototype, "storage", 1);
|
|
202
|
+
ObjectStackController = __decorateClass([
|
|
203
|
+
(0, import_common.Controller)("api")
|
|
220
204
|
], ObjectStackController);
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
}
|
|
205
|
+
var ObjectStackModule = class {
|
|
206
|
+
static forRoot(kernel) {
|
|
207
|
+
const kernelProvider = {
|
|
208
|
+
provide: OBJECT_KERNEL,
|
|
209
|
+
useValue: kernel
|
|
210
|
+
};
|
|
211
|
+
return {
|
|
212
|
+
module: ObjectStackModule,
|
|
213
|
+
controllers: [ObjectStackController],
|
|
214
|
+
providers: [kernelProvider, ObjectStackService],
|
|
215
|
+
exports: [kernelProvider, ObjectStackService]
|
|
216
|
+
};
|
|
217
|
+
}
|
|
235
218
|
};
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
(0, common_1.Module)({})
|
|
219
|
+
ObjectStackModule = __decorateClass([
|
|
220
|
+
(0, import_common.Global)(),
|
|
221
|
+
(0, import_common.Module)({})
|
|
240
222
|
], ObjectStackModule);
|
|
223
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
224
|
+
0 && (module.exports = {
|
|
225
|
+
ConnectReq,
|
|
226
|
+
OBJECT_KERNEL,
|
|
227
|
+
ObjectStackController,
|
|
228
|
+
ObjectStackModule,
|
|
229
|
+
ObjectStackService
|
|
230
|
+
});
|
|
231
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["import { DynamicModule, Module, Global, Inject, Provider, Controller, Post, Get, Body, Query, Req, Res, All, createParamDecorator, ExecutionContext } from '@nestjs/common';\nimport { Injectable } from '@nestjs/common';\nimport { ObjectKernel, HttpDispatcher, HttpDispatcherResult } from '@objectstack/runtime';\n\nexport const OBJECT_KERNEL = 'OBJECT_KERNEL';\n\nexport const ConnectReq = createParamDecorator(\n (_data: unknown, ctx: ExecutionContext) => {\n return ctx.switchToHttp().getRequest();\n },\n);\n\n// --- Service ---\n\n@Injectable()\nexport class ObjectStackService {\n public dispatcher: HttpDispatcher;\n\n constructor(@Inject(OBJECT_KERNEL) private readonly kernel: ObjectKernel) {\n this.dispatcher = new HttpDispatcher(kernel);\n }\n\n getKernel() {\n return this.kernel;\n }\n}\n\n// --- Controller ---\n\n@Controller('api')\nexport class ObjectStackController {\n constructor(private readonly service: ObjectStackService) {}\n\n private async normalizeResponse(result: HttpDispatcherResult, res: any) {\n if (result.handled) {\n if (result.response) {\n res.status(result.response.status);\n if (result.response.headers) {\n Object.entries(result.response.headers).forEach(([k, v]) => res.setHeader(k, v));\n }\n return res.json(result.response.body);\n }\n if (result.result) {\n const response = result.result;\n \n // Handle redirect\n if (response.type === 'redirect' && response.url) {\n return res.redirect(response.url);\n }\n\n // Handle stream\n if (response.type === 'stream' && response.stream) {\n if (response.headers) {\n Object.entries(response.headers).forEach(([k, v]) => res.setHeader(k, v));\n }\n response.stream.pipe(res);\n return;\n }\n \n // If response is a standard Response object\n if (response && typeof response.status === 'number' && typeof response.text === 'function') {\n res.status(response.status);\n if (response.headers && typeof response.headers.forEach === 'function') {\n response.headers.forEach((v: string, k: string) => res.setHeader(k, v));\n }\n const text = await response.text();\n res.send(text);\n return;\n }\n return res.status(200).json(response);\n }\n }\n return res.status(404).json({ success: false, error: { message: 'Not Found', code: 404 } });\n }\n\n private async handleError(err: any, res: any) {\n return res.status(err.statusCode || 500).json({ \n success: false, \n error: { \n message: err.message || 'Internal Server Error', \n code: err.statusCode || 500,\n details: err.details \n } \n });\n }\n\n // --- Discovery Endpoint ---\n @Get()\n discovery() {\n return this.service.dispatcher.getDiscoveryInfo('/api');\n }\n\n @Post('graphql')\n async graphql(@Body() body: any, @Req() req: any, @Res() res: any) {\n try {\n const result = await this.service.dispatcher.handleGraphQL(body, { request: req });\n return res.json(result);\n } catch (err) {\n return this.handleError(err, res);\n }\n }\n\n // Auth (Generic Auth Handler)\n @All('auth/*')\n async auth(@Req() req: any, @Res() res: any, @Body() body: any) {\n try {\n const path = req.params[0] || req.url.split('/auth/')[1]?.split('?')[0] || '';\n const result = await this.service.dispatcher.handleAuth(path, req.method, body, { request: req, response: res });\n return this.normalizeResponse(result, res);\n } catch (err: any) {\n return this.handleError(err, res);\n }\n }\n\n // Metadata\n @All('metadata*')\n async metadata(@Req() req: any, @Res() res: any, @Body() body?: any) {\n try {\n // /api/metadata/objects -> objects\n let path = req.params[0] || ''; \n if (req.url.includes('/metadata')) {\n path = req.url.split('/metadata')[1].split('?')[0];\n }\n \n // Use injected body or fallback to req.body\n const payload = body || req.body;\n \n const result = await this.service.dispatcher.handleMetadata(path, { request: req }, req.method, payload);\n return this.normalizeResponse(result, res);\n } catch (err) {\n return this.handleError(err, res);\n }\n }\n\n // Data\n @All('data*')\n async data(@Req() req: any, @Res() res: any, @Body() body: any, @Query() query: any) {\n try {\n let path = req.params[0] || '';\n if (req.url.includes('/data')) {\n path = req.url.substring(req.url.indexOf('/data') + 5).split('?')[0];\n }\n \n const result = await this.service.dispatcher.handleData(path, req.method, body, query, { request: req });\n return this.normalizeResponse(result, res);\n } catch (err) {\n return this.handleError(err, res);\n }\n }\n\n // Storage\n @All('storage*')\n async storage(@Req() req: any, @Res() res: any) {\n try {\n let path = req.params[0] || '';\n if (req.url.includes('/storage')) {\n path = req.url.substring(req.url.indexOf('/storage') + 8).split('?')[0];\n }\n\n // Handle File for NestJS (Express/Fastify)\n const file = req.file || req.files?.file;\n \n const result = await this.service.dispatcher.handleStorage(path, req.method, file, { request: req });\n return this.normalizeResponse(result, res);\n } catch (err) {\n return this.handleError(err, res);\n }\n }\n}\n\n// --- Module ---\n\n@Global()\n@Module({})\nexport class ObjectStackModule {\n static forRoot(kernel: ObjectKernel): DynamicModule {\n const kernelProvider: Provider = {\n provide: OBJECT_KERNEL,\n useValue: kernel,\n };\n\n return {\n module: ObjectStackModule,\n controllers: [ObjectStackController],\n providers: [kernelProvider, ObjectStackService],\n exports: [kernelProvider, ObjectStackService],\n };\n }\n}\n"],"mappings":"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","names":["import_common"]}
|
package/dist/index.mjs
ADDED
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __decorateClass = (decorators, target, key, kind) => {
|
|
4
|
+
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
|
|
5
|
+
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
|
6
|
+
if (decorator = decorators[i])
|
|
7
|
+
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
|
8
|
+
if (kind && result) __defProp(target, key, result);
|
|
9
|
+
return result;
|
|
10
|
+
};
|
|
11
|
+
var __decorateParam = (index, decorator) => (target, key) => decorator(target, key, index);
|
|
12
|
+
|
|
13
|
+
// src/index.ts
|
|
14
|
+
import { Module, Global, Inject, Controller, Post, Get, Body, Query, Req, Res, All, createParamDecorator } from "@nestjs/common";
|
|
15
|
+
import { Injectable } from "@nestjs/common";
|
|
16
|
+
import { HttpDispatcher } from "@objectstack/runtime";
|
|
17
|
+
var OBJECT_KERNEL = "OBJECT_KERNEL";
|
|
18
|
+
var ConnectReq = createParamDecorator(
|
|
19
|
+
(_data, ctx) => {
|
|
20
|
+
return ctx.switchToHttp().getRequest();
|
|
21
|
+
}
|
|
22
|
+
);
|
|
23
|
+
var ObjectStackService = class {
|
|
24
|
+
constructor(kernel) {
|
|
25
|
+
this.kernel = kernel;
|
|
26
|
+
this.dispatcher = new HttpDispatcher(kernel);
|
|
27
|
+
}
|
|
28
|
+
getKernel() {
|
|
29
|
+
return this.kernel;
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
ObjectStackService = __decorateClass([
|
|
33
|
+
Injectable(),
|
|
34
|
+
__decorateParam(0, Inject(OBJECT_KERNEL))
|
|
35
|
+
], ObjectStackService);
|
|
36
|
+
var ObjectStackController = class {
|
|
37
|
+
constructor(service) {
|
|
38
|
+
this.service = service;
|
|
39
|
+
}
|
|
40
|
+
async normalizeResponse(result, res) {
|
|
41
|
+
if (result.handled) {
|
|
42
|
+
if (result.response) {
|
|
43
|
+
res.status(result.response.status);
|
|
44
|
+
if (result.response.headers) {
|
|
45
|
+
Object.entries(result.response.headers).forEach(([k, v]) => res.setHeader(k, v));
|
|
46
|
+
}
|
|
47
|
+
return res.json(result.response.body);
|
|
48
|
+
}
|
|
49
|
+
if (result.result) {
|
|
50
|
+
const response = result.result;
|
|
51
|
+
if (response.type === "redirect" && response.url) {
|
|
52
|
+
return res.redirect(response.url);
|
|
53
|
+
}
|
|
54
|
+
if (response.type === "stream" && response.stream) {
|
|
55
|
+
if (response.headers) {
|
|
56
|
+
Object.entries(response.headers).forEach(([k, v]) => res.setHeader(k, v));
|
|
57
|
+
}
|
|
58
|
+
response.stream.pipe(res);
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
if (response && typeof response.status === "number" && typeof response.text === "function") {
|
|
62
|
+
res.status(response.status);
|
|
63
|
+
if (response.headers && typeof response.headers.forEach === "function") {
|
|
64
|
+
response.headers.forEach((v, k) => res.setHeader(k, v));
|
|
65
|
+
}
|
|
66
|
+
const text = await response.text();
|
|
67
|
+
res.send(text);
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
70
|
+
return res.status(200).json(response);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
return res.status(404).json({ success: false, error: { message: "Not Found", code: 404 } });
|
|
74
|
+
}
|
|
75
|
+
async handleError(err, res) {
|
|
76
|
+
return res.status(err.statusCode || 500).json({
|
|
77
|
+
success: false,
|
|
78
|
+
error: {
|
|
79
|
+
message: err.message || "Internal Server Error",
|
|
80
|
+
code: err.statusCode || 500,
|
|
81
|
+
details: err.details
|
|
82
|
+
}
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
discovery() {
|
|
86
|
+
return this.service.dispatcher.getDiscoveryInfo("/api");
|
|
87
|
+
}
|
|
88
|
+
async graphql(body, req, res) {
|
|
89
|
+
try {
|
|
90
|
+
const result = await this.service.dispatcher.handleGraphQL(body, { request: req });
|
|
91
|
+
return res.json(result);
|
|
92
|
+
} catch (err) {
|
|
93
|
+
return this.handleError(err, res);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
async auth(req, res, body) {
|
|
97
|
+
try {
|
|
98
|
+
const path = req.params[0] || req.url.split("/auth/")[1]?.split("?")[0] || "";
|
|
99
|
+
const result = await this.service.dispatcher.handleAuth(path, req.method, body, { request: req, response: res });
|
|
100
|
+
return this.normalizeResponse(result, res);
|
|
101
|
+
} catch (err) {
|
|
102
|
+
return this.handleError(err, res);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
async metadata(req, res, body) {
|
|
106
|
+
try {
|
|
107
|
+
let path = req.params[0] || "";
|
|
108
|
+
if (req.url.includes("/metadata")) {
|
|
109
|
+
path = req.url.split("/metadata")[1].split("?")[0];
|
|
110
|
+
}
|
|
111
|
+
const payload = body || req.body;
|
|
112
|
+
const result = await this.service.dispatcher.handleMetadata(path, { request: req }, req.method, payload);
|
|
113
|
+
return this.normalizeResponse(result, res);
|
|
114
|
+
} catch (err) {
|
|
115
|
+
return this.handleError(err, res);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
async data(req, res, body, query) {
|
|
119
|
+
try {
|
|
120
|
+
let path = req.params[0] || "";
|
|
121
|
+
if (req.url.includes("/data")) {
|
|
122
|
+
path = req.url.substring(req.url.indexOf("/data") + 5).split("?")[0];
|
|
123
|
+
}
|
|
124
|
+
const result = await this.service.dispatcher.handleData(path, req.method, body, query, { request: req });
|
|
125
|
+
return this.normalizeResponse(result, res);
|
|
126
|
+
} catch (err) {
|
|
127
|
+
return this.handleError(err, res);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
async storage(req, res) {
|
|
131
|
+
try {
|
|
132
|
+
let path = req.params[0] || "";
|
|
133
|
+
if (req.url.includes("/storage")) {
|
|
134
|
+
path = req.url.substring(req.url.indexOf("/storage") + 8).split("?")[0];
|
|
135
|
+
}
|
|
136
|
+
const file = req.file || req.files?.file;
|
|
137
|
+
const result = await this.service.dispatcher.handleStorage(path, req.method, file, { request: req });
|
|
138
|
+
return this.normalizeResponse(result, res);
|
|
139
|
+
} catch (err) {
|
|
140
|
+
return this.handleError(err, res);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
};
|
|
144
|
+
__decorateClass([
|
|
145
|
+
Get()
|
|
146
|
+
], ObjectStackController.prototype, "discovery", 1);
|
|
147
|
+
__decorateClass([
|
|
148
|
+
Post("graphql"),
|
|
149
|
+
__decorateParam(0, Body()),
|
|
150
|
+
__decorateParam(1, Req()),
|
|
151
|
+
__decorateParam(2, Res())
|
|
152
|
+
], ObjectStackController.prototype, "graphql", 1);
|
|
153
|
+
__decorateClass([
|
|
154
|
+
All("auth/*"),
|
|
155
|
+
__decorateParam(0, Req()),
|
|
156
|
+
__decorateParam(1, Res()),
|
|
157
|
+
__decorateParam(2, Body())
|
|
158
|
+
], ObjectStackController.prototype, "auth", 1);
|
|
159
|
+
__decorateClass([
|
|
160
|
+
All("metadata*"),
|
|
161
|
+
__decorateParam(0, Req()),
|
|
162
|
+
__decorateParam(1, Res()),
|
|
163
|
+
__decorateParam(2, Body())
|
|
164
|
+
], ObjectStackController.prototype, "metadata", 1);
|
|
165
|
+
__decorateClass([
|
|
166
|
+
All("data*"),
|
|
167
|
+
__decorateParam(0, Req()),
|
|
168
|
+
__decorateParam(1, Res()),
|
|
169
|
+
__decorateParam(2, Body()),
|
|
170
|
+
__decorateParam(3, Query())
|
|
171
|
+
], ObjectStackController.prototype, "data", 1);
|
|
172
|
+
__decorateClass([
|
|
173
|
+
All("storage*"),
|
|
174
|
+
__decorateParam(0, Req()),
|
|
175
|
+
__decorateParam(1, Res())
|
|
176
|
+
], ObjectStackController.prototype, "storage", 1);
|
|
177
|
+
ObjectStackController = __decorateClass([
|
|
178
|
+
Controller("api")
|
|
179
|
+
], ObjectStackController);
|
|
180
|
+
var ObjectStackModule = class {
|
|
181
|
+
static forRoot(kernel) {
|
|
182
|
+
const kernelProvider = {
|
|
183
|
+
provide: OBJECT_KERNEL,
|
|
184
|
+
useValue: kernel
|
|
185
|
+
};
|
|
186
|
+
return {
|
|
187
|
+
module: ObjectStackModule,
|
|
188
|
+
controllers: [ObjectStackController],
|
|
189
|
+
providers: [kernelProvider, ObjectStackService],
|
|
190
|
+
exports: [kernelProvider, ObjectStackService]
|
|
191
|
+
};
|
|
192
|
+
}
|
|
193
|
+
};
|
|
194
|
+
ObjectStackModule = __decorateClass([
|
|
195
|
+
Global(),
|
|
196
|
+
Module({})
|
|
197
|
+
], ObjectStackModule);
|
|
198
|
+
export {
|
|
199
|
+
ConnectReq,
|
|
200
|
+
OBJECT_KERNEL,
|
|
201
|
+
ObjectStackController,
|
|
202
|
+
ObjectStackModule,
|
|
203
|
+
ObjectStackService
|
|
204
|
+
};
|
|
205
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["import { DynamicModule, Module, Global, Inject, Provider, Controller, Post, Get, Body, Query, Req, Res, All, createParamDecorator, ExecutionContext } from '@nestjs/common';\nimport { Injectable } from '@nestjs/common';\nimport { ObjectKernel, HttpDispatcher, HttpDispatcherResult } from '@objectstack/runtime';\n\nexport const OBJECT_KERNEL = 'OBJECT_KERNEL';\n\nexport const ConnectReq = createParamDecorator(\n (_data: unknown, ctx: ExecutionContext) => {\n return ctx.switchToHttp().getRequest();\n },\n);\n\n// --- Service ---\n\n@Injectable()\nexport class ObjectStackService {\n public dispatcher: HttpDispatcher;\n\n constructor(@Inject(OBJECT_KERNEL) private readonly kernel: ObjectKernel) {\n this.dispatcher = new HttpDispatcher(kernel);\n }\n\n getKernel() {\n return this.kernel;\n }\n}\n\n// --- Controller ---\n\n@Controller('api')\nexport class ObjectStackController {\n constructor(private readonly service: ObjectStackService) {}\n\n private async normalizeResponse(result: HttpDispatcherResult, res: any) {\n if (result.handled) {\n if (result.response) {\n res.status(result.response.status);\n if (result.response.headers) {\n Object.entries(result.response.headers).forEach(([k, v]) => res.setHeader(k, v));\n }\n return res.json(result.response.body);\n }\n if (result.result) {\n const response = result.result;\n \n // Handle redirect\n if (response.type === 'redirect' && response.url) {\n return res.redirect(response.url);\n }\n\n // Handle stream\n if (response.type === 'stream' && response.stream) {\n if (response.headers) {\n Object.entries(response.headers).forEach(([k, v]) => res.setHeader(k, v));\n }\n response.stream.pipe(res);\n return;\n }\n \n // If response is a standard Response object\n if (response && typeof response.status === 'number' && typeof response.text === 'function') {\n res.status(response.status);\n if (response.headers && typeof response.headers.forEach === 'function') {\n response.headers.forEach((v: string, k: string) => res.setHeader(k, v));\n }\n const text = await response.text();\n res.send(text);\n return;\n }\n return res.status(200).json(response);\n }\n }\n return res.status(404).json({ success: false, error: { message: 'Not Found', code: 404 } });\n }\n\n private async handleError(err: any, res: any) {\n return res.status(err.statusCode || 500).json({ \n success: false, \n error: { \n message: err.message || 'Internal Server Error', \n code: err.statusCode || 500,\n details: err.details \n } \n });\n }\n\n // --- Discovery Endpoint ---\n @Get()\n discovery() {\n return this.service.dispatcher.getDiscoveryInfo('/api');\n }\n\n @Post('graphql')\n async graphql(@Body() body: any, @Req() req: any, @Res() res: any) {\n try {\n const result = await this.service.dispatcher.handleGraphQL(body, { request: req });\n return res.json(result);\n } catch (err) {\n return this.handleError(err, res);\n }\n }\n\n // Auth (Generic Auth Handler)\n @All('auth/*')\n async auth(@Req() req: any, @Res() res: any, @Body() body: any) {\n try {\n const path = req.params[0] || req.url.split('/auth/')[1]?.split('?')[0] || '';\n const result = await this.service.dispatcher.handleAuth(path, req.method, body, { request: req, response: res });\n return this.normalizeResponse(result, res);\n } catch (err: any) {\n return this.handleError(err, res);\n }\n }\n\n // Metadata\n @All('metadata*')\n async metadata(@Req() req: any, @Res() res: any, @Body() body?: any) {\n try {\n // /api/metadata/objects -> objects\n let path = req.params[0] || ''; \n if (req.url.includes('/metadata')) {\n path = req.url.split('/metadata')[1].split('?')[0];\n }\n \n // Use injected body or fallback to req.body\n const payload = body || req.body;\n \n const result = await this.service.dispatcher.handleMetadata(path, { request: req }, req.method, payload);\n return this.normalizeResponse(result, res);\n } catch (err) {\n return this.handleError(err, res);\n }\n }\n\n // Data\n @All('data*')\n async data(@Req() req: any, @Res() res: any, @Body() body: any, @Query() query: any) {\n try {\n let path = req.params[0] || '';\n if (req.url.includes('/data')) {\n path = req.url.substring(req.url.indexOf('/data') + 5).split('?')[0];\n }\n \n const result = await this.service.dispatcher.handleData(path, req.method, body, query, { request: req });\n return this.normalizeResponse(result, res);\n } catch (err) {\n return this.handleError(err, res);\n }\n }\n\n // Storage\n @All('storage*')\n async storage(@Req() req: any, @Res() res: any) {\n try {\n let path = req.params[0] || '';\n if (req.url.includes('/storage')) {\n path = req.url.substring(req.url.indexOf('/storage') + 8).split('?')[0];\n }\n\n // Handle File for NestJS (Express/Fastify)\n const file = req.file || req.files?.file;\n \n const result = await this.service.dispatcher.handleStorage(path, req.method, file, { request: req });\n return this.normalizeResponse(result, res);\n } catch (err) {\n return this.handleError(err, res);\n }\n }\n}\n\n// --- Module ---\n\n@Global()\n@Module({})\nexport class ObjectStackModule {\n static forRoot(kernel: ObjectKernel): DynamicModule {\n const kernelProvider: Provider = {\n provide: OBJECT_KERNEL,\n useValue: kernel,\n };\n\n return {\n module: ObjectStackModule,\n controllers: [ObjectStackController],\n providers: [kernelProvider, ObjectStackService],\n exports: [kernelProvider, ObjectStackService],\n };\n }\n}\n"],"mappings":"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","names":[]}
|
package/package.json
CHANGED
|
@@ -1,21 +1,21 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@objectstack/nestjs",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.6",
|
|
4
4
|
"license": "Apache-2.0",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
7
7
|
"peerDependencies": {
|
|
8
8
|
"@nestjs/common": "^10.0.0",
|
|
9
9
|
"@nestjs/core": "^10.0.0",
|
|
10
|
-
"@objectstack/runtime": "1.0.
|
|
10
|
+
"@objectstack/runtime": "1.0.6"
|
|
11
11
|
},
|
|
12
12
|
"devDependencies": {
|
|
13
13
|
"@nestjs/common": "^10.0.0",
|
|
14
14
|
"@nestjs/core": "^10.0.0",
|
|
15
15
|
"typescript": "^5.0.0",
|
|
16
|
-
"@objectstack/runtime": "1.0.
|
|
16
|
+
"@objectstack/runtime": "1.0.6"
|
|
17
17
|
},
|
|
18
18
|
"scripts": {
|
|
19
|
-
"build": "
|
|
19
|
+
"build": "tsup --config ../../../tsup.config.ts"
|
|
20
20
|
}
|
|
21
21
|
}
|
package/dist/index.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAA+H,MAAM,gBAAgB,CAAC;AAE5K,OAAO,EAAE,YAAY,EAAE,cAAc,EAAwB,MAAM,sBAAsB,CAAC;AAE1F,eAAO,MAAM,aAAa,kBAAkB,CAAC;AAE7C,eAAO,MAAM,UAAU,mDAItB,CAAC;AAIF,qBACa,kBAAkB;IAGM,OAAO,CAAC,QAAQ,CAAC,MAAM;IAFnD,UAAU,EAAE,cAAc,CAAC;gBAEkB,MAAM,EAAE,YAAY;IAIxE,SAAS;CAGV;AAID,qBACa,qBAAqB;IACpB,OAAO,CAAC,QAAQ,CAAC,OAAO;gBAAP,OAAO,EAAE,kBAAkB;YAE1C,iBAAiB;YA0CjB,WAAW;IAazB,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;IAKH,OAAO,CAAS,IAAI,EAAE,GAAG,EAAS,GAAG,EAAE,GAAG,EAAS,GAAG,EAAE,GAAG;IAW3D,IAAI,CAAQ,GAAG,EAAE,GAAG,EAAS,GAAG,EAAE,GAAG,EAAU,IAAI,EAAE,GAAG;IAYxD,QAAQ,CAAQ,GAAG,EAAE,GAAG,EAAS,GAAG,EAAE,GAAG,EAAU,IAAI,CAAC,EAAE,GAAG;IAoB7D,IAAI,CAAQ,GAAG,EAAE,GAAG,EAAS,GAAG,EAAE,GAAG,EAAU,IAAI,EAAE,GAAG,EAAW,KAAK,EAAE,GAAG;IAgB7E,OAAO,CAAQ,GAAG,EAAE,GAAG,EAAS,GAAG,EAAE,GAAG;CAgB/C;AAID,qBAEa,iBAAiB;IAC5B,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,YAAY,GAAG,aAAa;CAapD"}
|