@dnax/core 0.2.8 → 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 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: c.req.raw.headers.get("CF-Connecting-IP"),
47
- isAuth: decode?._v?.isAuth ? true : false,
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: jwt.sign(sessionStorage().get().state),
285
+ token: sessionStorage().get().token,
282
286
  });
283
287
  } else {
284
288
  c.status(401);
@@ -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 { state: object; _v: object; token: string }) || {
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: { state: object; _v?: object; token?: string | undefined | null } = {
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
- token: input.token || this.get().token,
68
+ access: input?.access || {},
69
+ token: generateToken,
32
70
  });
33
71
  },
34
72
  });
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dnax/core",
3
- "version": "0.2.8",
3
+ "version": "0.2.9",
4
4
  "module": "index.ts",
5
5
  "type": "module",
6
6
  "bin": {
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: { state: object | any; token?: string; _v?: object }) => void;
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
- if (!token || token?.replace(/\s/g, "") === "") return null;
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
  }