create-velox-app 0.6.75 → 0.6.76

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 CHANGED
@@ -1,5 +1,11 @@
1
1
  # create-velox-app
2
2
 
3
+ ## 0.6.76
4
+
5
+ ### Patch Changes
6
+
7
+ - fix(create): resolve all template type errors for zero-error scaffolding
8
+
3
9
  ## 0.6.75
4
10
 
5
11
  ### Patch Changes
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "create-velox-app",
3
- "version": "0.6.75",
3
+ "version": "0.6.76",
4
4
  "description": "Project scaffolder for VeloxTS framework",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",
@@ -2,7 +2,16 @@
2
2
  * Application Configuration
3
3
  */
4
4
 
5
- import type { FastifyLoggerOptions } from 'fastify';
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 | FastifyLoggerOptions {
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
- } as const;
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: PrismaClient | undefined;
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(): PrismaClient {
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(): PrismaClient {
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
- const tokenId = ctx.auth?.token?.jti;
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: (user.name as string) || '',
243
+ name: user.name ?? '',
243
244
  email: user.email,
244
245
  roles: Array.isArray(user.roles) ? user.roles : ['user'],
245
246
  };
@@ -7,7 +7,7 @@
7
7
  * IMPORTANT: Keep this file browser-safe - no Node.js imports or side effects.
8
8
  */
9
9
 
10
- import type { RouteMap } from '@veloxts/router';
10
+ import type { RouteMap } from '@veloxts/velox';
11
11
 
12
12
  /**
13
13
  * Route mappings for the VeloxTS client
@@ -8,27 +8,21 @@
8
8
  import { z } from 'zod';
9
9
 
10
10
  // ============================================================================
11
- // Timestamp Helper
11
+ // User Schema
12
12
  // ============================================================================
13
13
 
14
14
  /**
15
- * Schema that accepts Date or string and outputs ISO string.
16
- * Handles Prisma Date objects JSON-safe strings.
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: dateToString,
31
- updatedAt: dateToString,
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 './generated/prisma/client.js';
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
+ }
@@ -238,7 +238,7 @@ export const authProcedures = procedures('auth', {
238
238
 
239
239
  return {
240
240
  id: user.id,
241
- name: (user.name as string) || '',
241
+ name: user.name ?? '',
242
242
  email: user.email,
243
243
  roles: Array.isArray(user.roles) ? user.roles : ['user'],
244
244
  };
@@ -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
  };