naystack 1.1.13 → 1.1.15

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.
@@ -151,7 +151,10 @@ var getUserContext = (refreshKey, signingKey, req) => {
151
151
  };
152
152
 
153
153
  // src/auth/email/routes/delete.ts
154
- var getDeleteRoute = () => () => getTokenizedResponse(void 0, "");
154
+ var getDeleteRoute = (options) => async (req) => {
155
+ if (options.onLogout) await options.onLogout?.(await req.text());
156
+ return getTokenizedResponse(void 0, "");
157
+ };
155
158
 
156
159
  // src/auth/email/routes/get.ts
157
160
  var getGetRoute = (options) => (req) => {
@@ -216,7 +219,7 @@ function getEmailAuthRoutes(options) {
216
219
  GET: getGetRoute(options),
217
220
  POST: getPostRoute(options),
218
221
  PUT: getPutRoute(options),
219
- DELETE: getDeleteRoute(),
222
+ DELETE: getDeleteRoute(options),
220
223
  getUserIdFromRequest: (req) => getUserContext(options.refreshKey, options.signingKey, req)
221
224
  };
222
225
  }
@@ -10,10 +10,10 @@ declare function getEmailAuthRoutes(options: InitRoutesOptions): {
10
10
  }>;
11
11
  POST: (req: NextRequest) => Promise<next_server.NextResponse<unknown> | undefined>;
12
12
  PUT: (req: NextRequest) => Promise<next_server.NextResponse<unknown> | undefined>;
13
- DELETE: () => next_server.NextResponse<{
13
+ DELETE: (req: NextRequest) => Promise<next_server.NextResponse<{
14
14
  accessToken: string | undefined;
15
15
  refreshToken: string | undefined;
16
- }>;
16
+ }>>;
17
17
  getUserIdFromRequest: (req: NextRequest) => {
18
18
  refreshUserID?: number;
19
19
  accessUserId?: number;
@@ -10,10 +10,10 @@ declare function getEmailAuthRoutes(options: InitRoutesOptions): {
10
10
  }>;
11
11
  POST: (req: NextRequest) => Promise<next_server.NextResponse<unknown> | undefined>;
12
12
  PUT: (req: NextRequest) => Promise<next_server.NextResponse<unknown> | undefined>;
13
- DELETE: () => next_server.NextResponse<{
13
+ DELETE: (req: NextRequest) => Promise<next_server.NextResponse<{
14
14
  accessToken: string | undefined;
15
15
  refreshToken: string | undefined;
16
- }>;
16
+ }>>;
17
17
  getUserIdFromRequest: (req: NextRequest) => {
18
18
  refreshUserID?: number;
19
19
  accessUserId?: number;
@@ -125,7 +125,10 @@ var getUserContext = (refreshKey, signingKey, req) => {
125
125
  };
126
126
 
127
127
  // src/auth/email/routes/delete.ts
128
- var getDeleteRoute = () => () => getTokenizedResponse(void 0, "");
128
+ var getDeleteRoute = (options) => async (req) => {
129
+ if (options.onLogout) await options.onLogout?.(await req.text());
130
+ return getTokenizedResponse(void 0, "");
131
+ };
129
132
 
130
133
  // src/auth/email/routes/get.ts
131
134
  var getGetRoute = (options) => (req) => {
@@ -190,7 +193,7 @@ function getEmailAuthRoutes(options) {
190
193
  GET: getGetRoute(options),
191
194
  POST: getPostRoute(options),
192
195
  PUT: getPutRoute(options),
193
- DELETE: getDeleteRoute(),
196
+ DELETE: getDeleteRoute(options),
194
197
  getUserIdFromRequest: (req) => getUserContext(options.refreshKey, options.signingKey, req)
195
198
  };
196
199
  }
@@ -51,7 +51,10 @@ function getTokenizedResponse(accessToken, refreshToken) {
51
51
  }
52
52
 
53
53
  // src/auth/email/routes/delete.ts
54
- var getDeleteRoute = () => () => getTokenizedResponse(void 0, "");
54
+ var getDeleteRoute = (options) => async (req) => {
55
+ if (options.onLogout) await options.onLogout?.(await req.text());
56
+ return getTokenizedResponse(void 0, "");
57
+ };
55
58
  // Annotate the CommonJS export names for ESM import in node:
56
59
  0 && (module.exports = {
57
60
  getDeleteRoute
@@ -1,8 +1,11 @@
1
1
  import * as next_server from 'next/server';
2
+ import { NextRequest } from 'next/server';
3
+ import { InitRoutesOptions } from '../types.mjs';
4
+ import '../../types.mjs';
2
5
 
3
- declare const getDeleteRoute: () => () => next_server.NextResponse<{
6
+ declare const getDeleteRoute: (options: InitRoutesOptions) => (req: NextRequest) => Promise<next_server.NextResponse<{
4
7
  accessToken: string | undefined;
5
8
  refreshToken: string | undefined;
6
- }>;
9
+ }>>;
7
10
 
8
11
  export { getDeleteRoute };
@@ -1,8 +1,11 @@
1
1
  import * as next_server from 'next/server';
2
+ import { NextRequest } from 'next/server';
3
+ import { InitRoutesOptions } from '../types.js';
4
+ import '../../types.js';
2
5
 
3
- declare const getDeleteRoute: () => () => next_server.NextResponse<{
6
+ declare const getDeleteRoute: (options: InitRoutesOptions) => (req: NextRequest) => Promise<next_server.NextResponse<{
4
7
  accessToken: string | undefined;
5
8
  refreshToken: string | undefined;
6
- }>;
9
+ }>>;
7
10
 
8
11
  export { getDeleteRoute };
@@ -25,7 +25,10 @@ function getTokenizedResponse(accessToken, refreshToken) {
25
25
  }
26
26
 
27
27
  // src/auth/email/routes/delete.ts
28
- var getDeleteRoute = () => () => getTokenizedResponse(void 0, "");
28
+ var getDeleteRoute = (options) => async (req) => {
29
+ if (options.onLogout) await options.onLogout?.(await req.text());
30
+ return getTokenizedResponse(void 0, "");
31
+ };
29
32
  export {
30
33
  getDeleteRoute
31
34
  };
@@ -9,6 +9,7 @@ type InitRoutesOptions = {
9
9
  refreshKey: string;
10
10
  turnstileKey?: string;
11
11
  onSignUp: (user: UserOutput) => void;
12
+ onLogout?: (body: string) => Promise<void>;
12
13
  };
13
14
 
14
15
  export type { InitRoutesOptions };
@@ -9,6 +9,7 @@ type InitRoutesOptions = {
9
9
  refreshKey: string;
10
10
  turnstileKey?: string;
11
11
  onSignUp: (user: UserOutput) => void;
12
+ onLogout?: (body: string) => Promise<void>;
12
13
  };
13
14
 
14
15
  export type { InitRoutesOptions };
@@ -165,7 +165,10 @@ var getUserContext = (refreshKey, signingKey, req) => {
165
165
  };
166
166
 
167
167
  // src/auth/email/routes/delete.ts
168
- var getDeleteRoute = () => () => getTokenizedResponse(void 0, "");
168
+ var getDeleteRoute = (options) => async (req) => {
169
+ if (options.onLogout) await options.onLogout?.(await req.text());
170
+ return getTokenizedResponse(void 0, "");
171
+ };
169
172
 
170
173
  // src/auth/email/routes/get.ts
171
174
  var getGetRoute = (options) => (req) => {
@@ -230,7 +233,7 @@ function getEmailAuthRoutes(options) {
230
233
  GET: getGetRoute(options),
231
234
  POST: getPostRoute(options),
232
235
  PUT: getPutRoute(options),
233
- DELETE: getDeleteRoute(),
236
+ DELETE: getDeleteRoute(options),
234
237
  getUserIdFromRequest: (req) => getUserContext(options.refreshKey, options.signingKey, req)
235
238
  };
236
239
  }
@@ -137,7 +137,10 @@ var getUserContext = (refreshKey, signingKey, req) => {
137
137
  };
138
138
 
139
139
  // src/auth/email/routes/delete.ts
140
- var getDeleteRoute = () => () => getTokenizedResponse(void 0, "");
140
+ var getDeleteRoute = (options) => async (req) => {
141
+ if (options.onLogout) await options.onLogout?.(await req.text());
142
+ return getTokenizedResponse(void 0, "");
143
+ };
141
144
 
142
145
  // src/auth/email/routes/get.ts
143
146
  var getGetRoute = (options) => (req) => {
@@ -202,7 +205,7 @@ function getEmailAuthRoutes(options) {
202
205
  GET: getGetRoute(options),
203
206
  POST: getPostRoute(options),
204
207
  PUT: getPutRoute(options),
205
- DELETE: getDeleteRoute(),
208
+ DELETE: getDeleteRoute(options),
206
209
  getUserIdFromRequest: (req) => getUserContext(options.refreshKey, options.signingKey, req)
207
210
  };
208
211
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "naystack",
3
- "version": "1.1.13",
3
+ "version": "1.1.15",
4
4
  "description": "A stack built with tight Next + Drizzle + GraphQL",
5
5
  "main": "dist/index.cjs.js",
6
6
  "module": "dist/index.esm.js",
@@ -68,8 +68,8 @@
68
68
  "drizzle-orm": "^0.44.5",
69
69
  "googleapis": "^160.0.0",
70
70
  "jsonwebtoken": "^9.0.2",
71
- "next": "^15.6.0-canary.39",
72
- "react": "^19.1.0",
71
+ "next": "^15.6.0-canary.58",
72
+ "react": "^19.1.2",
73
73
  "react-dom": "^19.1.0",
74
74
  "reflect-metadata": "^0.2.2",
75
75
  "type-graphql": "2.0.0-rc.2",