@dnax/core 0.2.7 → 0.2.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/app/hono.ts +8 -4
- package/driver/mongo/rest.ts +2 -2
- package/lib/asyncLocalStorage.ts +42 -4
- package/lib/schema.ts +6 -1
- package/package.json +1 -1
- package/types/index.ts +17 -1
- package/utils/index.ts +3 -1
package/app/hono.ts
CHANGED
|
@@ -43,13 +43,17 @@ function HonoInstance(): typeof app {
|
|
|
43
43
|
c.set("isStudio", isStudio(secretKeyStudio));
|
|
44
44
|
c.set("_v", {
|
|
45
45
|
token: token || null,
|
|
46
|
-
ip:
|
|
47
|
-
|
|
46
|
+
ip:
|
|
47
|
+
c.req.raw.headers?.get("CF-Connecting-IP") ||
|
|
48
|
+
c.req.raw.headers?.get("x-forwarded-for") ||
|
|
49
|
+
c.req.raw.headers?.get("x-real-ip"),
|
|
50
|
+
isAuth: valid ? true : false,
|
|
48
51
|
});
|
|
49
52
|
c.set("tenant-id", c.req.header()["tenant-id"]);
|
|
50
53
|
if (token && valid) {
|
|
51
54
|
session.set({
|
|
52
|
-
state: decode,
|
|
55
|
+
state: decode?.state || {},
|
|
56
|
+
access: decode?.access || {},
|
|
53
57
|
_v: c.var?._v || {},
|
|
54
58
|
token: token,
|
|
55
59
|
});
|
|
@@ -278,7 +282,7 @@ function HonoInstance(): typeof app {
|
|
|
278
282
|
return c.json({
|
|
279
283
|
auth: true,
|
|
280
284
|
data: responseAuth,
|
|
281
|
-
token:
|
|
285
|
+
token: sessionStorage().get().token,
|
|
282
286
|
});
|
|
283
287
|
} else {
|
|
284
288
|
c.status(401);
|
package/driver/mongo/rest.ts
CHANGED
|
@@ -298,7 +298,7 @@ class useRest {
|
|
|
298
298
|
}),
|
|
299
299
|
});
|
|
300
300
|
}
|
|
301
|
-
return resolve(data);
|
|
301
|
+
return resolve(toJson(data));
|
|
302
302
|
} catch (err) {
|
|
303
303
|
return reject(err);
|
|
304
304
|
}
|
|
@@ -659,7 +659,7 @@ class useRest {
|
|
|
659
659
|
update.$set = transformAllDate(update.$set);
|
|
660
660
|
update.$set = await hashPasswordAuto(update.$set, col);
|
|
661
661
|
// data = transformAllDate(data);
|
|
662
|
-
//
|
|
662
|
+
//update.$set = deepSetId(col, update.$set);
|
|
663
663
|
var { valid, output, error } = this.validator(
|
|
664
664
|
collection,
|
|
665
665
|
update.$set,
|
package/lib/asyncLocalStorage.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { AsyncLocalStorage } from "node:async_hooks";
|
|
2
2
|
import type { sessionCtx } from "../types";
|
|
3
|
+
import { jwt } from "../utils";
|
|
3
4
|
const asyncLocalStorage = new AsyncLocalStorage();
|
|
4
5
|
const key = "___sessionStorage___";
|
|
5
6
|
const stateKey = "____requestState____";
|
|
@@ -7,7 +8,23 @@ const sessionStorage = () => ({
|
|
|
7
8
|
get(): { state: object; _v: object; token: string } {
|
|
8
9
|
let store = asyncLocalStorage.getStore() as InstanceType<typeof Map>;
|
|
9
10
|
return (
|
|
10
|
-
(store.get(key) as {
|
|
11
|
+
(store.get(key) as {
|
|
12
|
+
state: object;
|
|
13
|
+
_v: object;
|
|
14
|
+
token: string;
|
|
15
|
+
access: {
|
|
16
|
+
aggreate?: boolean;
|
|
17
|
+
find?: boolean;
|
|
18
|
+
findOne?: boolean;
|
|
19
|
+
insertOne?: boolean;
|
|
20
|
+
insertMany?: boolean;
|
|
21
|
+
updateOne?: boolean;
|
|
22
|
+
updateMany?: boolean;
|
|
23
|
+
deleteOne?: boolean;
|
|
24
|
+
deleteMany?: boolean;
|
|
25
|
+
upload?: boolean;
|
|
26
|
+
};
|
|
27
|
+
}) || {
|
|
11
28
|
state: {},
|
|
12
29
|
_v: {},
|
|
13
30
|
token: "",
|
|
@@ -15,20 +32,41 @@ const sessionStorage = () => ({
|
|
|
15
32
|
);
|
|
16
33
|
},
|
|
17
34
|
set(
|
|
18
|
-
input: {
|
|
35
|
+
input: {
|
|
36
|
+
state: object;
|
|
37
|
+
_v?: object;
|
|
38
|
+
token?: string | undefined | null;
|
|
39
|
+
access?: {
|
|
40
|
+
aggreate?: boolean;
|
|
41
|
+
find?: boolean;
|
|
42
|
+
findOne?: boolean;
|
|
43
|
+
insertOne?: boolean;
|
|
44
|
+
insertMany?: boolean;
|
|
45
|
+
updateOne?: boolean;
|
|
46
|
+
updateMany?: boolean;
|
|
47
|
+
deleteOne?: boolean;
|
|
48
|
+
deleteMany?: boolean;
|
|
49
|
+
upload?: boolean;
|
|
50
|
+
};
|
|
51
|
+
} = {
|
|
19
52
|
state: {},
|
|
20
53
|
_v: {},
|
|
21
|
-
token: null,
|
|
54
|
+
// token: null,
|
|
22
55
|
}
|
|
23
56
|
) {
|
|
24
57
|
let store = asyncLocalStorage.getStore() as InstanceType<typeof Map>;
|
|
58
|
+
let generateToken = jwt.sign({
|
|
59
|
+
state: input.state,
|
|
60
|
+
access: input?.access || {},
|
|
61
|
+
});
|
|
25
62
|
store.set(key, {
|
|
26
63
|
...this.get(),
|
|
27
64
|
state: {
|
|
28
65
|
...this.get().state,
|
|
29
66
|
...input.state,
|
|
30
67
|
},
|
|
31
|
-
|
|
68
|
+
access: input?.access || {},
|
|
69
|
+
token: generateToken,
|
|
32
70
|
});
|
|
33
71
|
},
|
|
34
72
|
});
|
package/lib/schema.ts
CHANGED
|
@@ -50,7 +50,12 @@ function buildSchema(col: Collection) {
|
|
|
50
50
|
}
|
|
51
51
|
|
|
52
52
|
if (f?.type == "relationship") {
|
|
53
|
-
propertySchema[f.name] = v
|
|
53
|
+
propertySchema[f.name] = v
|
|
54
|
+
.string()
|
|
55
|
+
.optional()
|
|
56
|
+
.messages({
|
|
57
|
+
"string.base": `${f.name} must be ObjectId or String`,
|
|
58
|
+
});
|
|
54
59
|
}
|
|
55
60
|
|
|
56
61
|
if (f?.type == "relationship" && f.relation?.hasMany) {
|
package/package.json
CHANGED
package/types/index.ts
CHANGED
|
@@ -158,7 +158,23 @@ export type accessCtx = (ctx: {
|
|
|
158
158
|
}) => boolean | undefined | void | Promise<any>;
|
|
159
159
|
|
|
160
160
|
export type sessionCtx = {
|
|
161
|
-
set: (session: {
|
|
161
|
+
set: (session: {
|
|
162
|
+
state: object | any;
|
|
163
|
+
token?: string;
|
|
164
|
+
_v?: object;
|
|
165
|
+
access?: {
|
|
166
|
+
aggreate?: boolean;
|
|
167
|
+
find?: boolean;
|
|
168
|
+
findOne?: boolean;
|
|
169
|
+
insertOne?: boolean;
|
|
170
|
+
insertMany?: boolean;
|
|
171
|
+
updateOne?: boolean;
|
|
172
|
+
updateMany?: boolean;
|
|
173
|
+
deleteOne?: boolean;
|
|
174
|
+
deleteMany?: boolean;
|
|
175
|
+
upload?: boolean;
|
|
176
|
+
};
|
|
177
|
+
}) => void;
|
|
162
178
|
get: () => { state: object; _v: object };
|
|
163
179
|
};
|
|
164
180
|
|
package/utils/index.ts
CHANGED
|
@@ -31,7 +31,9 @@ const jwt = {
|
|
|
31
31
|
getToken: (prefix = "Bearer", input: string): string | null => {
|
|
32
32
|
if (input?.startsWith(prefix)) {
|
|
33
33
|
let token = input?.slice(prefix?.length + 1);
|
|
34
|
-
|
|
34
|
+
let getToken = (token as string) || null;
|
|
35
|
+
if (!token || token?.replace(/\s/g, "") === "") getToken = null;
|
|
36
|
+
return getToken;
|
|
35
37
|
} else {
|
|
36
38
|
return null;
|
|
37
39
|
}
|