@bgord/bun 0.17.0 → 0.18.0
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/auth-shield.middleware.d.ts +11 -24
- package/dist/auth-shield.middleware.d.ts.map +1 -1
- package/dist/auth-shield.middleware.js +21 -60
- package/dist/auth-shield.middleware.js.map +1 -1
- package/dist/index.d.ts +0 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +0 -3
- package/dist/index.js.map +1 -1
- package/dist/policy.service.d.ts +3 -3
- package/dist/policy.service.d.ts.map +1 -1
- package/dist/policy.service.js +4 -4
- package/dist/policy.service.js.map +1 -1
- package/dist/setup.service.d.ts +8 -2
- package/dist/setup.service.d.ts.map +1 -1
- package/dist/setup.service.js +4 -2
- package/dist/setup.service.js.map +1 -1
- package/dist/translations.service.d.ts +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +8 -8
- package/readme.md +0 -3
- package/src/auth-shield.middleware.ts +24 -97
- package/src/index.ts +0 -3
- package/src/policy.service.ts +5 -5
- package/src/setup.service.ts +10 -2
- package/dist/passwords.vo.d.ts +0 -21
- package/dist/passwords.vo.d.ts.map +0 -1
- package/dist/passwords.vo.js +0 -42
- package/dist/passwords.vo.js.map +0 -1
- package/dist/session-id.vo.d.ts +0 -7
- package/dist/session-id.vo.d.ts.map +0 -1
- package/dist/session-id.vo.js +0 -10
- package/dist/session-id.vo.js.map +0 -1
- package/dist/username.vo.d.ts +0 -11
- package/dist/username.vo.d.ts.map +0 -1
- package/dist/username.vo.js +0 -13
- package/dist/username.vo.js.map +0 -1
- package/src/passwords.vo.ts +0 -56
- package/src/session-id.vo.ts +0 -13
- package/src/username.vo.ts +0 -20
|
@@ -1,31 +1,18 @@
|
|
|
1
|
+
import type { betterAuth } from "better-auth";
|
|
1
2
|
import hono from "hono";
|
|
2
3
|
import { HTTPException } from "hono/http-exception";
|
|
3
|
-
import { Lucia } from "lucia";
|
|
4
|
-
import { HashedPassword, Password, PasswordType } from "./passwords.vo";
|
|
5
|
-
import { IdType, Username } from "./username.vo";
|
|
6
|
-
type AuthShieldConfigType<T> = {
|
|
7
|
-
Username: typeof Username;
|
|
8
|
-
Password: typeof Password;
|
|
9
|
-
HashedPassword: typeof HashedPassword;
|
|
10
|
-
lucia: Lucia;
|
|
11
|
-
findUniqueUserOrThrow: (username: Username) => Promise<T>;
|
|
12
|
-
};
|
|
13
4
|
export declare const AccessDeniedAuthShieldError: HTTPException;
|
|
14
|
-
export declare class AuthShield
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
}
|
|
5
|
+
export declare class AuthShield {
|
|
6
|
+
private readonly Auth;
|
|
7
|
+
cors: {
|
|
8
|
+
origin: string[];
|
|
9
|
+
credentials: boolean;
|
|
10
|
+
allowHeaders: string[];
|
|
11
|
+
exposeHeaders: string[];
|
|
12
|
+
};
|
|
13
|
+
constructor(Auth: ReturnType<typeof betterAuth>);
|
|
14
|
+
attach: hono.MiddlewareHandler<any, any, {}>;
|
|
24
15
|
verify: hono.MiddlewareHandler<any, any, {}>;
|
|
25
16
|
reverse: hono.MiddlewareHandler<any, any, {}>;
|
|
26
|
-
detach: hono.MiddlewareHandler<any, any, {}>;
|
|
27
|
-
build: hono.MiddlewareHandler<any, any, {}>;
|
|
28
|
-
attach: hono.MiddlewareHandler<any, any, {}>;
|
|
29
17
|
}
|
|
30
|
-
export {};
|
|
31
18
|
//# sourceMappingURL=auth-shield.middleware.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth-shield.middleware.d.ts","sourceRoot":"","sources":["../src/auth-shield.middleware.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"auth-shield.middleware.d.ts","sourceRoot":"","sources":["../src/auth-shield.middleware.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,IAAI,MAAM,MAAM,CAAC;AAExB,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD,eAAO,MAAM,2BAA2B,eAEtC,CAAC;AAEH,qBAAa,UAAU;IAQT,OAAO,CAAC,QAAQ,CAAC,IAAI;IAPjC,IAAI;;;;;MAKF;gBAE2B,IAAI,EAAE,UAAU,CAAC,OAAO,UAAU,CAAC;IAEhE,MAAM,uCAYH;IAEH,MAAM,uCAQH;IAEH,OAAO,uCAQJ;CACJ"}
|
|
@@ -1,23 +1,31 @@
|
|
|
1
|
+
// TODO: tests
|
|
1
2
|
import { createMiddleware } from "hono/factory";
|
|
2
3
|
import { HTTPException } from "hono/http-exception";
|
|
3
|
-
import { HashedPassword, Password } from "./passwords.vo";
|
|
4
|
-
import { SessionId } from "./session-id.vo";
|
|
5
|
-
import { Username } from "./username.vo";
|
|
6
4
|
export const AccessDeniedAuthShieldError = new HTTPException(403, {
|
|
7
5
|
message: "access_denied_auth_shield",
|
|
8
6
|
});
|
|
9
7
|
export class AuthShield {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
this.config = config;
|
|
8
|
+
Auth;
|
|
9
|
+
cors = {
|
|
10
|
+
origin: ["http://localhost:5173", "http://localhost:3000"],
|
|
11
|
+
credentials: true,
|
|
12
|
+
allowHeaders: ["Content-Type"],
|
|
13
|
+
exposeHeaders: ["Set-Cookie"],
|
|
14
|
+
};
|
|
15
|
+
constructor(Auth) {
|
|
16
|
+
this.Auth = Auth;
|
|
20
17
|
}
|
|
18
|
+
attach = createMiddleware(async (c, next) => {
|
|
19
|
+
const session = await this.Auth.api.getSession({ headers: c.req.raw.headers });
|
|
20
|
+
if (!session) {
|
|
21
|
+
c.set("user", null);
|
|
22
|
+
c.set("session", null);
|
|
23
|
+
return next();
|
|
24
|
+
}
|
|
25
|
+
c.set("user", session.user);
|
|
26
|
+
c.set("session", session.session);
|
|
27
|
+
return next();
|
|
28
|
+
});
|
|
21
29
|
verify = createMiddleware(async (c, next) => {
|
|
22
30
|
const user = c.get("user");
|
|
23
31
|
if (!user) {
|
|
@@ -32,52 +40,5 @@ export class AuthShield {
|
|
|
32
40
|
}
|
|
33
41
|
return next();
|
|
34
42
|
});
|
|
35
|
-
detach = createMiddleware(async (c, next) => {
|
|
36
|
-
const cookie = c.req.header("cookie");
|
|
37
|
-
const sessionId = new SessionId(cookie, this.config.lucia).get();
|
|
38
|
-
if (!sessionId)
|
|
39
|
-
return next();
|
|
40
|
-
await this.config.lucia.invalidateSession(sessionId);
|
|
41
|
-
return next();
|
|
42
|
-
});
|
|
43
|
-
build = createMiddleware(async (c, next) => {
|
|
44
|
-
const cookie = c.req.header("cookie");
|
|
45
|
-
const sessionId = new SessionId(cookie, this.config.lucia).get();
|
|
46
|
-
if (!sessionId) {
|
|
47
|
-
c.set("user", null);
|
|
48
|
-
c.set("session", null);
|
|
49
|
-
return next();
|
|
50
|
-
}
|
|
51
|
-
const { session, user } = await this.config.lucia.validateSession(sessionId);
|
|
52
|
-
if (!session) {
|
|
53
|
-
c.res.headers.set("Set-Cookie", this.config.lucia.createBlankSessionCookie().serialize());
|
|
54
|
-
c.set("user", null);
|
|
55
|
-
c.set("session", null);
|
|
56
|
-
return next();
|
|
57
|
-
}
|
|
58
|
-
if (session.fresh) {
|
|
59
|
-
c.res.headers.set("Set-Cookie", this.config.lucia.createSessionCookie(session.id).serialize());
|
|
60
|
-
}
|
|
61
|
-
c.set("user", user);
|
|
62
|
-
c.set("session", session);
|
|
63
|
-
return next();
|
|
64
|
-
});
|
|
65
|
-
attach = createMiddleware(async (c, next) => {
|
|
66
|
-
try {
|
|
67
|
-
const body = await c.req.raw.clone().formData();
|
|
68
|
-
const username = new this.config.Username(body.get("username"));
|
|
69
|
-
const password = new this.config.Password(body.get("password"));
|
|
70
|
-
const user = await this.config.findUniqueUserOrThrow(username);
|
|
71
|
-
const hashedPassword = await this.config.HashedPassword.fromHash(user.password);
|
|
72
|
-
await hashedPassword.matchesOrThrow(password);
|
|
73
|
-
const session = await this.config.lucia.createSession(user.id, {});
|
|
74
|
-
const sessionCookie = this.config.lucia.createSessionCookie(session.id);
|
|
75
|
-
c.res.headers.set("Set-Cookie", sessionCookie.serialize());
|
|
76
|
-
return next();
|
|
77
|
-
}
|
|
78
|
-
catch (_error) {
|
|
79
|
-
throw AccessDeniedAuthShieldError;
|
|
80
|
-
}
|
|
81
|
-
});
|
|
82
43
|
}
|
|
83
44
|
//# sourceMappingURL=auth-shield.middleware.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth-shield.middleware.js","sourceRoot":"","sources":["../src/auth-shield.middleware.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"auth-shield.middleware.js","sourceRoot":"","sources":["../src/auth-shield.middleware.ts"],"names":[],"mappings":"AAAA,cAAc;AAId,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD,MAAM,CAAC,MAAM,2BAA2B,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE;IAChE,OAAO,EAAE,2BAA2B;CACrC,CAAC,CAAC;AAEH,MAAM,OAAO,UAAU;IAQQ;IAP7B,IAAI,GAAG;QACL,MAAM,EAAE,CAAC,uBAAuB,EAAE,uBAAuB,CAAC;QAC1D,WAAW,EAAE,IAAI;QACjB,YAAY,EAAE,CAAC,cAAc,CAAC;QAC9B,aAAa,EAAE,CAAC,YAAY,CAAC;KAC9B,CAAC;IAEF,YAA6B,IAAmC;QAAnC,SAAI,GAAJ,IAAI,CAA+B;IAAG,CAAC;IAEpE,MAAM,GAAG,gBAAgB,CAAC,KAAK,EAAE,CAAe,EAAE,IAAe,EAAE,EAAE;QACnE,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;QAE/E,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;YACpB,CAAC,CAAC,GAAG,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;YACvB,OAAO,IAAI,EAAE,CAAC;QAChB,CAAC;QAED,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;QAC5B,CAAC,CAAC,GAAG,CAAC,SAAS,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC;QAClC,OAAO,IAAI,EAAE,CAAC;IAChB,CAAC,CAAC,CAAC;IAEH,MAAM,GAAG,gBAAgB,CAAC,KAAK,EAAE,CAAe,EAAE,IAAe,EAAE,EAAE;QACnE,MAAM,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAE3B,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,MAAM,2BAA2B,CAAC;QACpC,CAAC;QAED,OAAO,IAAI,EAAE,CAAC;IAChB,CAAC,CAAC,CAAC;IAEH,OAAO,GAAG,gBAAgB,CAAC,KAAK,EAAE,CAAe,EAAE,IAAe,EAAE,EAAE;QACpE,MAAM,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAE3B,IAAI,IAAI,EAAE,CAAC;YACT,MAAM,2BAA2B,CAAC;QACpC,CAAC;QAED,OAAO,IAAI,EAAE,CAAC;IAChB,CAAC,CAAC,CAAC;CACJ"}
|
package/dist/index.d.ts
CHANGED
|
@@ -40,7 +40,6 @@ export * from "./memory-consumption.service";
|
|
|
40
40
|
export * from "./new-uuid.service";
|
|
41
41
|
export * from "./node-env.vo";
|
|
42
42
|
export * from "./open-graph.service";
|
|
43
|
-
export * from "./passwords.vo";
|
|
44
43
|
export * from "./path.vo";
|
|
45
44
|
export * from "./policy.service";
|
|
46
45
|
export * from "./policy-error-handler.service";
|
|
@@ -50,7 +49,6 @@ export * from "./prerequisites.service";
|
|
|
50
49
|
export * from "./rate-limit-shield.middleware";
|
|
51
50
|
export * from "./recaptcha-shield.middleware";
|
|
52
51
|
export * from "./safe-parse-body.service";
|
|
53
|
-
export * from "./session-id.vo";
|
|
54
52
|
export * from "./setup.service";
|
|
55
53
|
export * from "./simulated-error.middleware";
|
|
56
54
|
export * from "./sitemap.service";
|
|
@@ -60,7 +58,6 @@ export * from "./to-event-map.types";
|
|
|
60
58
|
export * from "./translations.service";
|
|
61
59
|
export * from "./uptime.service";
|
|
62
60
|
export * from "./url-wo-trailing-slash.vo";
|
|
63
|
-
export * from "./username.vo";
|
|
64
61
|
export * from "./uuid.vo";
|
|
65
62
|
export * from "./weak-etag-extractor.middleware";
|
|
66
63
|
//# 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,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,OAAO,CAAC;AAEzC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,0BAA0B,CAAC;AACzC,cAAc,0BAA0B,CAAC;AACzC,cAAc,sBAAsB,CAAC;AACrC,cAAc,iCAAiC,CAAC;AAChD,cAAc,0BAA0B,CAAC;AACzC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,iCAAiC,CAAC;AAChD,cAAc,iBAAiB,CAAC;AAChC,cAAc,kBAAkB,CAAC;AACjC,cAAc,sBAAsB,CAAC;AACrC,cAAc,qBAAqB,CAAC;AACpC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,sBAAsB,CAAC;AACrC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC;AACrC,cAAc,yBAAyB,CAAC;AACxC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,eAAe,CAAC;AAC9B,cAAc,yBAAyB,CAAC;AACxC,cAAc,wBAAwB,CAAC;AACvC,cAAc,eAAe,CAAC;AAC9B,cAAc,mBAAmB,CAAC;AAClC,cAAc,yBAAyB,CAAC;AACxC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,gBAAgB,CAAC;AAC/B,cAAc,8BAA8B,CAAC;AAC7C,cAAc,uBAAuB,CAAC;AACtC,cAAc,0BAA0B,CAAC;AACzC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,4BAA4B,CAAC;AAC3C,cAAc,sBAAsB,CAAC;AACrC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC;AACjC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,oBAAoB,CAAC;AACnC,cAAc,eAAe,CAAC;AAC9B,cAAc,sBAAsB,CAAC;AACrC,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,OAAO,CAAC;AAEzC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,0BAA0B,CAAC;AACzC,cAAc,0BAA0B,CAAC;AACzC,cAAc,sBAAsB,CAAC;AACrC,cAAc,iCAAiC,CAAC;AAChD,cAAc,0BAA0B,CAAC;AACzC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,iCAAiC,CAAC;AAChD,cAAc,iBAAiB,CAAC;AAChC,cAAc,kBAAkB,CAAC;AACjC,cAAc,sBAAsB,CAAC;AACrC,cAAc,qBAAqB,CAAC;AACpC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,sBAAsB,CAAC;AACrC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC;AACrC,cAAc,yBAAyB,CAAC;AACxC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,eAAe,CAAC;AAC9B,cAAc,yBAAyB,CAAC;AACxC,cAAc,wBAAwB,CAAC;AACvC,cAAc,eAAe,CAAC;AAC9B,cAAc,mBAAmB,CAAC;AAClC,cAAc,yBAAyB,CAAC;AACxC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,gBAAgB,CAAC;AAC/B,cAAc,8BAA8B,CAAC;AAC7C,cAAc,uBAAuB,CAAC;AACtC,cAAc,0BAA0B,CAAC;AACzC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,4BAA4B,CAAC;AAC3C,cAAc,sBAAsB,CAAC;AACrC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC;AACjC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,oBAAoB,CAAC;AACnC,cAAc,eAAe,CAAC;AAC9B,cAAc,sBAAsB,CAAC;AACrC,cAAc,WAAW,CAAC;AAC1B,cAAc,kBAAkB,CAAC;AACjC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,WAAW,CAAC;AAC1B,cAAc,uBAAuB,CAAC;AACtC,cAAc,yBAAyB,CAAC;AACxC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,iBAAiB,CAAC;AAChC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,sBAAsB,CAAC;AACrC,cAAc,wBAAwB,CAAC;AACvC,cAAc,kBAAkB,CAAC;AACjC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,WAAW,CAAC;AAC1B,cAAc,kCAAkC,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -40,7 +40,6 @@ export * from "./memory-consumption.service";
|
|
|
40
40
|
export * from "./new-uuid.service";
|
|
41
41
|
export * from "./node-env.vo";
|
|
42
42
|
export * from "./open-graph.service";
|
|
43
|
-
export * from "./passwords.vo";
|
|
44
43
|
export * from "./path.vo";
|
|
45
44
|
export * from "./policy.service";
|
|
46
45
|
export * from "./policy-error-handler.service";
|
|
@@ -50,7 +49,6 @@ export * from "./prerequisites.service";
|
|
|
50
49
|
export * from "./rate-limit-shield.middleware";
|
|
51
50
|
export * from "./recaptcha-shield.middleware";
|
|
52
51
|
export * from "./safe-parse-body.service";
|
|
53
|
-
export * from "./session-id.vo";
|
|
54
52
|
export * from "./setup.service";
|
|
55
53
|
export * from "./simulated-error.middleware";
|
|
56
54
|
export * from "./sitemap.service";
|
|
@@ -60,7 +58,6 @@ export * from "./to-event-map.types";
|
|
|
60
58
|
export * from "./translations.service";
|
|
61
59
|
export * from "./uptime.service";
|
|
62
60
|
export * from "./url-wo-trailing-slash.vo";
|
|
63
|
-
export * from "./username.vo";
|
|
64
61
|
export * from "./uuid.vo";
|
|
65
62
|
export * from "./weak-etag-extractor.middleware";
|
|
66
63
|
//# 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,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,OAAO,CAAC;AAEzC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,0BAA0B,CAAC;AACzC,cAAc,0BAA0B,CAAC;AACzC,cAAc,sBAAsB,CAAC;AACrC,cAAc,iCAAiC,CAAC;AAChD,cAAc,0BAA0B,CAAC;AACzC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,iCAAiC,CAAC;AAChD,cAAc,iBAAiB,CAAC;AAChC,cAAc,kBAAkB,CAAC;AACjC,cAAc,sBAAsB,CAAC;AACrC,cAAc,qBAAqB,CAAC;AACpC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,sBAAsB,CAAC;AACrC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC;AACrC,cAAc,yBAAyB,CAAC;AACxC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,eAAe,CAAC;AAC9B,cAAc,yBAAyB,CAAC;AACxC,cAAc,wBAAwB,CAAC;AACvC,cAAc,eAAe,CAAC;AAC9B,cAAc,mBAAmB,CAAC;AAClC,cAAc,yBAAyB,CAAC;AACxC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,gBAAgB,CAAC;AAC/B,cAAc,8BAA8B,CAAC;AAC7C,cAAc,uBAAuB,CAAC;AACtC,cAAc,0BAA0B,CAAC;AACzC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,4BAA4B,CAAC;AAC3C,cAAc,sBAAsB,CAAC;AACrC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC;AACjC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,oBAAoB,CAAC;AACnC,cAAc,eAAe,CAAC;AAC9B,cAAc,sBAAsB,CAAC;AACrC,cAAc,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,OAAO,CAAC;AAEzC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,0BAA0B,CAAC;AACzC,cAAc,0BAA0B,CAAC;AACzC,cAAc,sBAAsB,CAAC;AACrC,cAAc,iCAAiC,CAAC;AAChD,cAAc,0BAA0B,CAAC;AACzC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,iCAAiC,CAAC;AAChD,cAAc,iBAAiB,CAAC;AAChC,cAAc,kBAAkB,CAAC;AACjC,cAAc,sBAAsB,CAAC;AACrC,cAAc,qBAAqB,CAAC;AACpC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,sBAAsB,CAAC;AACrC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC;AACrC,cAAc,yBAAyB,CAAC;AACxC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,eAAe,CAAC;AAC9B,cAAc,yBAAyB,CAAC;AACxC,cAAc,wBAAwB,CAAC;AACvC,cAAc,eAAe,CAAC;AAC9B,cAAc,mBAAmB,CAAC;AAClC,cAAc,yBAAyB,CAAC;AACxC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,gBAAgB,CAAC;AAC/B,cAAc,8BAA8B,CAAC;AAC7C,cAAc,uBAAuB,CAAC;AACtC,cAAc,0BAA0B,CAAC;AACzC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,4BAA4B,CAAC;AAC3C,cAAc,sBAAsB,CAAC;AACrC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC;AACjC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,oBAAoB,CAAC;AACnC,cAAc,eAAe,CAAC;AAC9B,cAAc,sBAAsB,CAAC;AACrC,cAAc,WAAW,CAAC;AAC1B,cAAc,kBAAkB,CAAC;AACjC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,WAAW,CAAC;AAC1B,cAAc,uBAAuB,CAAC;AACtC,cAAc,yBAAyB,CAAC;AACxC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,iBAAiB,CAAC;AAChC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,sBAAsB,CAAC;AACrC,cAAc,wBAAwB,CAAC;AACvC,cAAc,kBAAkB,CAAC;AACjC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,WAAW,CAAC;AAC1B,cAAc,kCAAkC,CAAC"}
|
package/dist/policy.service.d.ts
CHANGED
|
@@ -2,13 +2,13 @@ import type { Constructor } from "@bgord/tools";
|
|
|
2
2
|
import type { ContentfulStatusCode } from "hono/utils/http-status";
|
|
3
3
|
type BasePolicyConfig = Record<string, unknown>;
|
|
4
4
|
export declare abstract class Policy<T extends BasePolicyConfig> {
|
|
5
|
-
abstract fails(config: T):
|
|
5
|
+
abstract fails(config: T): boolean;
|
|
6
6
|
abstract error: Constructor<Error>;
|
|
7
7
|
abstract message: string;
|
|
8
8
|
abstract code: ContentfulStatusCode;
|
|
9
9
|
throw(): void;
|
|
10
|
-
perform(config: T):
|
|
11
|
-
passes(config: T):
|
|
10
|
+
perform(config: T): void;
|
|
11
|
+
passes(config: T): boolean;
|
|
12
12
|
}
|
|
13
13
|
export {};
|
|
14
14
|
//# sourceMappingURL=policy.service.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"policy.service.d.ts","sourceRoot":"","sources":["../src/policy.service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAEnE,KAAK,gBAAgB,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AAEhD,8BAAsB,MAAM,CAAC,CAAC,SAAS,gBAAgB;IACrD,QAAQ,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,GAAG,OAAO
|
|
1
|
+
{"version":3,"file":"policy.service.d.ts","sourceRoot":"","sources":["../src/policy.service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAEnE,KAAK,gBAAgB,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AAEhD,8BAAsB,MAAM,CAAC,CAAC,SAAS,gBAAgB;IACrD,QAAQ,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,GAAG,OAAO;IAElC,QAAQ,CAAC,KAAK,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC;IAEnC,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;IAEzB,QAAQ,CAAC,IAAI,EAAE,oBAAoB,CAAC;IAEpC,KAAK;IAIL,OAAO,CAAC,MAAM,EAAE,CAAC;IAMjB,MAAM,CAAC,MAAM,EAAE,CAAC;CAGjB"}
|
package/dist/policy.service.js
CHANGED
|
@@ -2,13 +2,13 @@ export class Policy {
|
|
|
2
2
|
throw() {
|
|
3
3
|
throw new this.error();
|
|
4
4
|
}
|
|
5
|
-
|
|
6
|
-
if (
|
|
5
|
+
perform(config) {
|
|
6
|
+
if (this.fails(config)) {
|
|
7
7
|
this.throw();
|
|
8
8
|
}
|
|
9
9
|
}
|
|
10
|
-
|
|
11
|
-
return !
|
|
10
|
+
passes(config) {
|
|
11
|
+
return !this.fails(config);
|
|
12
12
|
}
|
|
13
13
|
}
|
|
14
14
|
//# sourceMappingURL=policy.service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"policy.service.js","sourceRoot":"","sources":["../src/policy.service.ts"],"names":[],"mappings":"AAKA,MAAM,OAAgB,MAAM;IAS1B,KAAK;QACH,MAAM,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;IACzB,CAAC;IAED,
|
|
1
|
+
{"version":3,"file":"policy.service.js","sourceRoot":"","sources":["../src/policy.service.ts"],"names":[],"mappings":"AAKA,MAAM,OAAgB,MAAM;IAS1B,KAAK;QACH,MAAM,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;IACzB,CAAC;IAED,OAAO,CAAC,MAAS;QACf,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC;YACvB,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,CAAC;IACH,CAAC;IAED,MAAM,CAAC,MAAS;QACd,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAC7B,CAAC;CACF"}
|
package/dist/setup.service.d.ts
CHANGED
|
@@ -1,9 +1,15 @@
|
|
|
1
|
+
import { cors } from "hono/cors";
|
|
1
2
|
import { I18nConfigType } from "./i18n.service";
|
|
2
3
|
import { Logger } from "./logger.service";
|
|
3
|
-
export declare const BODY_LIMIT_MAX_SIZE: number & import("
|
|
4
|
+
export declare const BODY_LIMIT_MAX_SIZE: number & import("better-auth/*").$brand<"SizeValue">;
|
|
5
|
+
type CorsOptions = Parameters<typeof cors>[0];
|
|
6
|
+
type SetupOverridesType = {
|
|
7
|
+
cors?: CorsOptions;
|
|
8
|
+
};
|
|
4
9
|
export declare class Setup {
|
|
5
|
-
static essentials(logger: Logger, i18n: I18nConfigType): (import("hono").MiddlewareHandler<any, string, {}> | import("hono").MiddlewareHandler<{
|
|
10
|
+
static essentials(logger: Logger, i18n: I18nConfigType, overrides?: SetupOverridesType): (import("hono").MiddlewareHandler<any, string, {}> | import("hono").MiddlewareHandler<{
|
|
6
11
|
Variables: import("./etag-extractor.middleware").EtagVariables;
|
|
7
12
|
}, string, {}>)[];
|
|
8
13
|
}
|
|
14
|
+
export {};
|
|
9
15
|
//# sourceMappingURL=setup.service.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setup.service.d.ts","sourceRoot":"","sources":["../src/setup.service.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"setup.service.d.ts","sourceRoot":"","sources":["../src/setup.service.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAYjC,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAI1C,eAAO,MAAM,mBAAmB,sDAGpB,CAAC;AAGb,KAAK,WAAW,GAAG,UAAU,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;AAE9C,KAAK,kBAAkB,GAAG;IAAE,IAAI,CAAC,EAAE,WAAW,CAAA;CAAE,CAAC;AAEjD,qBAAa,KAAK;IAChB,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,cAAc,EAAE,SAAS,CAAC,EAAE,kBAAkB;;;CAwBvF"}
|
package/dist/setup.service.js
CHANGED
|
@@ -19,16 +19,18 @@ export const BODY_LIMIT_MAX_SIZE = new tools.Size({
|
|
|
19
19
|
unit: tools.SizeUnit.kB,
|
|
20
20
|
}).toBytes();
|
|
21
21
|
export class Setup {
|
|
22
|
-
static essentials(logger, i18n) {
|
|
22
|
+
static essentials(logger, i18n, overrides) {
|
|
23
|
+
const corsOptions = overrides?.cors ?? { origin: "*" };
|
|
23
24
|
return [
|
|
24
25
|
secureHeaders(),
|
|
25
26
|
bodyLimit({ maxSize: BODY_LIMIT_MAX_SIZE }),
|
|
26
27
|
uaBlocker({ blocklist: BOTS_REGEX }),
|
|
27
28
|
ApiVersion.attach,
|
|
28
|
-
cors(
|
|
29
|
+
cors(corsOptions),
|
|
29
30
|
languageDetector({
|
|
30
31
|
supportedLanguages: Object.keys(i18n.supportedLanguages),
|
|
31
32
|
fallbackLanguage: i18n.defaultLanguage,
|
|
33
|
+
caches: false,
|
|
32
34
|
}),
|
|
33
35
|
requestId({ limitLength: 36, headerName: "x-correlation-id" }),
|
|
34
36
|
TimeZoneOffset.attach,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setup.service.js","sourceRoot":"","sources":["../src/setup.service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAErC,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AACvC,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC/C,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAGtD,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAErE,MAAM,CAAC,MAAM,mBAAmB,GAAG,IAAI,KAAK,CAAC,IAAI,CAAC;IAChD,KAAK,EAAE,GAAG;IACV,IAAI,EAAE,KAAK,CAAC,QAAQ,CAAC,EAAE;CACxB,CAAC,CAAC,OAAO,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"setup.service.js","sourceRoot":"","sources":["../src/setup.service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAErC,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AACvC,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC/C,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAGtD,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAErE,MAAM,CAAC,MAAM,mBAAmB,GAAG,IAAI,KAAK,CAAC,IAAI,CAAC;IAChD,KAAK,EAAE,GAAG;IACV,IAAI,EAAE,KAAK,CAAC,QAAQ,CAAC,EAAE;CACxB,CAAC,CAAC,OAAO,EAAE,CAAC;AAOb,MAAM,OAAO,KAAK;IAChB,MAAM,CAAC,UAAU,CAAC,MAAc,EAAE,IAAoB,EAAE,SAA8B;QACpF,MAAM,WAAW,GAAG,SAAS,EAAE,IAAI,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;QAEvD,OAAO;YACL,aAAa,EAAE;YACf,SAAS,CAAC,EAAE,OAAO,EAAE,mBAAmB,EAAE,CAAC;YAC3C,SAAS,CAAC,EAAE,SAAS,EAAE,UAAU,EAAE,CAAC;YACpC,UAAU,CAAC,MAAM;YACjB,IAAI,CAAC,WAAW,CAAC;YACjB,gBAAgB,CAAC;gBACf,kBAAkB,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC;gBACxD,gBAAgB,EAAE,IAAI,CAAC,eAAe;gBACtC,MAAM,EAAE,KAAK;aACd,CAAC;YACF,SAAS,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE,UAAU,EAAE,kBAAkB,EAAE,CAAC;YAC9D,cAAc,CAAC,MAAM;YACrB,OAAO,CAAC,MAAM;YACd,iBAAiB,CAAC,MAAM;YACxB,aAAa,CAAC,MAAM;YACpB,UAAU,CAAC,KAAK,CAAC,MAAM,CAAC;YACxB,MAAM,EAAE;YACR,kBAAkB,CAAC,MAAM,EAAE;SAC5B,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -3,7 +3,7 @@ export declare class Translations {
|
|
|
3
3
|
translations: {
|
|
4
4
|
[x: string]: string;
|
|
5
5
|
};
|
|
6
|
-
language: string & import("
|
|
6
|
+
language: string & import("better-auth/*").$brand<"Language">;
|
|
7
7
|
}, import("hono/utils/http-status").ContentfulStatusCode, "json">>>];
|
|
8
8
|
}
|
|
9
9
|
//# sourceMappingURL=translations.service.d.ts.map
|