sst 3.0.1-23 → 3.0.1-25
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/handler.d.ts +7 -7
- package/dist/auth/handler.js +3 -3
- package/dist/auth/session.d.ts +2 -10
- package/dist/auth/session.js +10 -3
- package/dist/resource.js +12 -11
- package/package.json +1 -1
package/dist/auth/handler.d.ts
CHANGED
|
@@ -39,17 +39,17 @@ export declare function AuthHandler<Providers extends Record<string, Adapter<any
|
|
|
39
39
|
session?: Sessions;
|
|
40
40
|
providers: Providers;
|
|
41
41
|
callbacks: {
|
|
42
|
-
index?(
|
|
43
|
-
error?(error: UnknownStateError): Promise<Response | undefined>;
|
|
42
|
+
index?(req: Request): Promise<Response>;
|
|
43
|
+
error?(error: UnknownStateError, req: Request): Promise<Response | undefined>;
|
|
44
44
|
auth: {
|
|
45
|
-
error?(error: MissingParameterError | UnauthorizedClientError | UnknownProviderError): Promise<Response>;
|
|
45
|
+
error?(error: MissingParameterError | UnauthorizedClientError | UnknownProviderError, req: Request): Promise<Response>;
|
|
46
46
|
start?(event: Request): Promise<void>;
|
|
47
|
-
allowClient(clientID: string, redirect: string): Promise<boolean>;
|
|
48
|
-
success(response: OnSuccessResponder<Sessions["$typeValues"]>, input: Result): Promise<Response>;
|
|
47
|
+
allowClient(clientID: string, redirect: string, req: Request): Promise<boolean>;
|
|
48
|
+
success(response: OnSuccessResponder<Sessions["$typeValues"]>, input: Result, req: Request): Promise<Response>;
|
|
49
49
|
};
|
|
50
50
|
connect?: {
|
|
51
|
-
error?(error: InvalidSessionError | UnknownProviderError): Promise<Response | undefined>;
|
|
52
|
-
start?(session: Sessions["$typeValues"],
|
|
51
|
+
error?(error: InvalidSessionError | UnknownProviderError, req: Request): Promise<Response | undefined>;
|
|
52
|
+
start?(session: Sessions["$typeValues"], req: Request): Promise<void>;
|
|
53
53
|
success?(session: Sessions["$typeValues"], input: {}): Promise<Response>;
|
|
54
54
|
};
|
|
55
55
|
};
|
package/dist/auth/handler.js
CHANGED
|
@@ -62,7 +62,7 @@ export function AuthHandler(input) {
|
|
|
62
62
|
const redirect_uri = getCookie(ctx, "redirect_uri");
|
|
63
63
|
const response_type = getCookie(ctx, "response_type");
|
|
64
64
|
if (!redirect_uri) {
|
|
65
|
-
return options.forward(ctx, await input.callbacks.auth.error(new UnknownStateError()));
|
|
65
|
+
return options.forward(ctx, await input.callbacks.auth.error(new UnknownStateError(), ctx.req.raw));
|
|
66
66
|
}
|
|
67
67
|
return await input.callbacks.auth.success({
|
|
68
68
|
async session(session) {
|
|
@@ -101,7 +101,7 @@ export function AuthHandler(input) {
|
|
|
101
101
|
ctx.status(400);
|
|
102
102
|
return ctx.text(`Unsupported response_type: ${response_type}`);
|
|
103
103
|
},
|
|
104
|
-
}, properties);
|
|
104
|
+
}, properties, ctx.req.raw);
|
|
105
105
|
},
|
|
106
106
|
forward(ctx, response) {
|
|
107
107
|
return ctx.newResponse(response.body, response.status, Object.fromEntries(response.headers.entries()));
|
|
@@ -176,7 +176,7 @@ export function AuthHandler(input) {
|
|
|
176
176
|
});
|
|
177
177
|
app.route(`/${name}`, route);
|
|
178
178
|
}
|
|
179
|
-
app.all("/*", async (c
|
|
179
|
+
app.all("/*", async (c) => {
|
|
180
180
|
return c.notFound();
|
|
181
181
|
});
|
|
182
182
|
console.log(app.routes);
|
package/dist/auth/session.d.ts
CHANGED
|
@@ -1,20 +1,12 @@
|
|
|
1
|
-
import { JWTPayload } from "jose";
|
|
2
1
|
export type SessionBuilder = ReturnType<typeof createSessionBuilder>;
|
|
3
2
|
export declare function createSessionBuilder<SessionTypes extends Record<string, any> = {}>(): {
|
|
4
|
-
|
|
3
|
+
verify(token: string): Promise<{ [type in keyof SessionTypes]: {
|
|
5
4
|
type: type;
|
|
6
5
|
properties: SessionTypes[type];
|
|
7
6
|
}; }[keyof SessionTypes] | {
|
|
8
7
|
type: "public";
|
|
9
8
|
properties: {};
|
|
10
|
-
}
|
|
11
|
-
verify(token: string): { [type in keyof SessionTypes]: {
|
|
12
|
-
type: type;
|
|
13
|
-
properties: SessionTypes[type];
|
|
14
|
-
}; }[keyof SessionTypes] | {
|
|
15
|
-
type: "public";
|
|
16
|
-
properties: {};
|
|
17
|
-
};
|
|
9
|
+
}>;
|
|
18
10
|
$type: SessionTypes;
|
|
19
11
|
$typeValues: { [type in keyof SessionTypes]: {
|
|
20
12
|
type: type;
|
package/dist/auth/session.js
CHANGED
|
@@ -1,8 +1,15 @@
|
|
|
1
|
+
import { importSPKI, jwtVerify } from "jose";
|
|
2
|
+
import { Resource } from "../resource.js";
|
|
1
3
|
export function createSessionBuilder() {
|
|
4
|
+
const auth = Object.values(Resource).find((value) => value.auth === true && value.publicKey);
|
|
5
|
+
if (!auth) {
|
|
6
|
+
throw new Error("No auth resource found");
|
|
7
|
+
}
|
|
8
|
+
const publicKey = auth.publicKey;
|
|
2
9
|
return {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
return
|
|
10
|
+
async verify(token) {
|
|
11
|
+
const result = await jwtVerify(token, await importSPKI(publicKey, "RS512"));
|
|
12
|
+
return result.payload;
|
|
6
13
|
},
|
|
7
14
|
$type: {},
|
|
8
15
|
$typeValues: {},
|
package/dist/resource.js
CHANGED
|
@@ -1,15 +1,16 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
const raw = {
|
|
2
|
+
// @ts-expect-error,
|
|
3
|
+
...globalThis.$SST_LINKS,
|
|
4
|
+
};
|
|
5
|
+
for (const [key, value] of Object.entries(process.env)) {
|
|
6
|
+
if (key.startsWith("SST_RESOURCE_") && value) {
|
|
7
|
+
raw[key.slice("SST_RESOURCE_".length)] = JSON.parse(value);
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
export const Resource = new Proxy(raw, {
|
|
3
11
|
get(target, prop) {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
if (env[envName]) {
|
|
7
|
-
return JSON.parse(env[envName]);
|
|
8
|
-
}
|
|
9
|
-
// @ts-expect-error
|
|
10
|
-
if (prop in (globalThis.$SST_LINKS || {})) {
|
|
11
|
-
// @ts-expect-error
|
|
12
|
-
return globalThis.$SST_LINKS[prop];
|
|
12
|
+
if (prop in target) {
|
|
13
|
+
return target[prop];
|
|
13
14
|
}
|
|
14
15
|
throw new Error(`"${prop}" is not linked`);
|
|
15
16
|
},
|