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.
@@ -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?(event: Request): Promise<Response>;
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"], event: Request): Promise<void>;
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
  };
@@ -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, next) => {
179
+ app.all("/*", async (c) => {
180
180
  return c.notFound();
181
181
  });
182
182
  console.log(app.routes);
@@ -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
- create<T extends ({ [type in keyof SessionTypes]: {
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
- })["type"]>(type: T, properties: SessionTypes[T], options?: JWTPayload): void;
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;
@@ -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
- create(type, properties, options) { },
4
- verify(token) {
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
- import { env } from "node:process";
2
- export const Resource = new Proxy({}, {
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
- // Read from environment first
5
- const envName = `SST_RESOURCE_${prop}`;
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
  },
package/package.json CHANGED
@@ -3,7 +3,7 @@
3
3
  "name": "sst",
4
4
  "type": "module",
5
5
  "sideEffects": false,
6
- "version": "3.0.1-23",
6
+ "version": "3.0.1-25",
7
7
  "main": "./dist/index.js",
8
8
  "exports": {
9
9
  ".": "./dist/index.js",