create-velox-app 0.6.75 → 0.6.77
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/CHANGELOG.md +12 -0
- package/package.json +1 -1
- package/src/templates/source/api/config/app.ts +13 -6
- package/src/templates/source/api/config/database.ts +3 -3
- package/src/templates/source/api/procedures/auth.ts +3 -2
- package/src/templates/source/api/routes.auth.ts +1 -1
- package/src/templates/source/api/schemas/user.ts +7 -13
- package/src/templates/source/api/types.d.ts +8 -1
- package/src/templates/source/rsc-auth/src/api/procedures/auth.ts +1 -1
- package/src/templates/source/web/main.tsx +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,17 @@
|
|
|
1
1
|
# create-velox-app
|
|
2
2
|
|
|
3
|
+
## 0.6.77
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- fix(core): remove duplicate Fastify type exports
|
|
8
|
+
|
|
9
|
+
## 0.6.76
|
|
10
|
+
|
|
11
|
+
### Patch Changes
|
|
12
|
+
|
|
13
|
+
- fix(create): resolve all template type errors for zero-error scaffolding
|
|
14
|
+
|
|
3
15
|
## 0.6.75
|
|
4
16
|
|
|
5
17
|
### Patch Changes
|
package/package.json
CHANGED
|
@@ -2,7 +2,16 @@
|
|
|
2
2
|
* Application Configuration
|
|
3
3
|
*/
|
|
4
4
|
|
|
5
|
-
|
|
5
|
+
/**
|
|
6
|
+
* Application configuration type
|
|
7
|
+
*/
|
|
8
|
+
export interface AppConfig {
|
|
9
|
+
port: number;
|
|
10
|
+
host: string;
|
|
11
|
+
logger: boolean | { level: string };
|
|
12
|
+
apiPrefix: string;
|
|
13
|
+
env: 'development' | 'production' | 'test';
|
|
14
|
+
}
|
|
6
15
|
|
|
7
16
|
/**
|
|
8
17
|
* Build logger configuration based on environment.
|
|
@@ -11,7 +20,7 @@ import type { FastifyLoggerOptions } from 'fastify';
|
|
|
11
20
|
* - LOG_LEVEL=debug: Enable debug-level logging
|
|
12
21
|
* - Default: Standard info-level logging
|
|
13
22
|
*/
|
|
14
|
-
function buildLoggerConfig(): boolean |
|
|
23
|
+
function buildLoggerConfig(): boolean | { level: string } {
|
|
15
24
|
const logLevel = process.env.LOG_LEVEL;
|
|
16
25
|
|
|
17
26
|
// Silent mode - no logging
|
|
@@ -28,12 +37,10 @@ function buildLoggerConfig(): boolean | FastifyLoggerOptions {
|
|
|
28
37
|
return true;
|
|
29
38
|
}
|
|
30
39
|
|
|
31
|
-
export const config = {
|
|
40
|
+
export const config: AppConfig = {
|
|
32
41
|
port: Number(process.env.PORT) || __API_PORT__,
|
|
33
42
|
host: process.env.HOST || '0.0.0.0',
|
|
34
43
|
logger: buildLoggerConfig(),
|
|
35
44
|
apiPrefix: process.env.API_PREFIX || '/api',
|
|
36
45
|
env: (process.env.NODE_ENV || 'development') as 'development' | 'production' | 'test',
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
export type AppConfig = typeof config;
|
|
46
|
+
};
|
|
@@ -39,7 +39,7 @@ const { PrismaClient } = require('@prisma/client') as {
|
|
|
39
39
|
declare global {
|
|
40
40
|
// Allow global `var` declarations for hot reload in development
|
|
41
41
|
// eslint-disable-next-line no-var
|
|
42
|
-
var __db:
|
|
42
|
+
var __db: PrismaClientType | undefined;
|
|
43
43
|
}
|
|
44
44
|
|
|
45
45
|
/* @if sqlite */
|
|
@@ -47,7 +47,7 @@ declare global {
|
|
|
47
47
|
* Create a Prisma client instance using the SQLite adapter.
|
|
48
48
|
* Validates that DATABASE_URL is set before creating the client.
|
|
49
49
|
*/
|
|
50
|
-
function createPrismaClient():
|
|
50
|
+
function createPrismaClient(): PrismaClientType {
|
|
51
51
|
const databaseUrl = process.env.DATABASE_URL;
|
|
52
52
|
|
|
53
53
|
if (!databaseUrl) {
|
|
@@ -70,7 +70,7 @@ function createPrismaClient(): PrismaClient {
|
|
|
70
70
|
* - PrismaPg now takes connectionString directly (not a Pool instance)
|
|
71
71
|
* - Pool management is handled internally by the adapter
|
|
72
72
|
*/
|
|
73
|
-
function createPrismaClient():
|
|
73
|
+
function createPrismaClient(): PrismaClientType {
|
|
74
74
|
const connectionString = process.env.DATABASE_URL;
|
|
75
75
|
|
|
76
76
|
if (!connectionString) {
|
|
@@ -214,7 +214,8 @@ export const authProcedures = procedures('auth', {
|
|
|
214
214
|
.guard(authenticated)
|
|
215
215
|
.output(LogoutResponse)
|
|
216
216
|
.mutation(async ({ ctx }) => {
|
|
217
|
-
|
|
217
|
+
// Narrow the discriminated union to access native JWT payload
|
|
218
|
+
const tokenId = ctx.auth?.authMode === 'native' ? ctx.auth.payload?.jti : undefined;
|
|
218
219
|
|
|
219
220
|
if (tokenId) {
|
|
220
221
|
tokenStore.revoke(tokenId, 15 * 60 * 1000);
|
|
@@ -239,7 +240,7 @@ export const authProcedures = procedures('auth', {
|
|
|
239
240
|
|
|
240
241
|
return {
|
|
241
242
|
id: user.id,
|
|
242
|
-
name:
|
|
243
|
+
name: user.name ?? '',
|
|
243
244
|
email: user.email,
|
|
244
245
|
roles: Array.isArray(user.roles) ? user.roles : ['user'],
|
|
245
246
|
};
|
|
@@ -8,27 +8,21 @@
|
|
|
8
8
|
import { z } from 'zod';
|
|
9
9
|
|
|
10
10
|
// ============================================================================
|
|
11
|
-
//
|
|
11
|
+
// User Schema
|
|
12
12
|
// ============================================================================
|
|
13
13
|
|
|
14
14
|
/**
|
|
15
|
-
*
|
|
16
|
-
*
|
|
15
|
+
* User response schema.
|
|
16
|
+
* Uses z.coerce.date() to safely handle both:
|
|
17
|
+
* - Date objects from Prisma (output)
|
|
18
|
+
* - ISO strings from JSON (input validation)
|
|
17
19
|
*/
|
|
18
|
-
const dateToString = z
|
|
19
|
-
.union([z.date(), z.string()])
|
|
20
|
-
.transform((val) => (val instanceof Date ? val.toISOString() : val));
|
|
21
|
-
|
|
22
|
-
// ============================================================================
|
|
23
|
-
// User Schema
|
|
24
|
-
// ============================================================================
|
|
25
|
-
|
|
26
20
|
export const UserSchema = z.object({
|
|
27
21
|
id: z.string().uuid(),
|
|
28
22
|
name: z.string().min(1).max(100),
|
|
29
23
|
email: z.string().email(),
|
|
30
|
-
createdAt:
|
|
31
|
-
updatedAt:
|
|
24
|
+
createdAt: z.coerce.date(),
|
|
25
|
+
updatedAt: z.coerce.date(),
|
|
32
26
|
});
|
|
33
27
|
|
|
34
28
|
export type User = z.infer<typeof UserSchema>;
|
|
@@ -5,10 +5,17 @@
|
|
|
5
5
|
* This enables full autocomplete for ctx.db in procedure handlers.
|
|
6
6
|
*/
|
|
7
7
|
|
|
8
|
-
import type { PrismaClient } from '
|
|
8
|
+
import type { PrismaClient } from '@prisma/client';
|
|
9
9
|
|
|
10
10
|
declare module '@veloxts/core' {
|
|
11
11
|
interface BaseContext {
|
|
12
12
|
db: PrismaClient;
|
|
13
13
|
}
|
|
14
14
|
}
|
|
15
|
+
|
|
16
|
+
// Extend User interface to include name field from Prisma model
|
|
17
|
+
declare module '@veloxts/auth' {
|
|
18
|
+
interface User {
|
|
19
|
+
name?: string;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
@@ -26,7 +26,7 @@ declare module '@tanstack/react-router' {
|
|
|
26
26
|
|
|
27
27
|
/* @if auth */
|
|
28
28
|
// Dynamic headers for auth - fetches token on each request
|
|
29
|
-
const getAuthHeaders = () => {
|
|
29
|
+
const getAuthHeaders = (): Record<string, string> => {
|
|
30
30
|
const token = localStorage.getItem('token');
|
|
31
31
|
return token ? { Authorization: `Bearer ${token}` } : {};
|
|
32
32
|
};
|