@objectstack/spec 0.1.2 → 0.2.0

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.
Files changed (58) hide show
  1. package/dist/data/filter.zod.d.ts +295 -0
  2. package/dist/data/filter.zod.d.ts.map +1 -0
  3. package/dist/data/filter.zod.js +226 -0
  4. package/dist/index.d.ts +2 -0
  5. package/dist/index.d.ts.map +1 -1
  6. package/dist/index.js +2 -0
  7. package/dist/system/auth.zod.d.ts +2287 -0
  8. package/dist/system/auth.zod.d.ts.map +1 -0
  9. package/dist/system/auth.zod.js +365 -0
  10. package/dist/system/datasource.zod.d.ts +118 -38
  11. package/dist/system/datasource.zod.d.ts.map +1 -1
  12. package/dist/system/datasource.zod.js +25 -6
  13. package/dist/system/driver.zod.d.ts +106 -0
  14. package/dist/system/driver.zod.d.ts.map +1 -1
  15. package/dist/system/driver.zod.js +47 -0
  16. package/dist/system/policy.zod.d.ts +10 -10
  17. package/dist/ui/dashboard.zod.d.ts +10 -10
  18. package/dist/ui/dashboard.zod.d.ts.map +1 -1
  19. package/dist/ui/dashboard.zod.js +3 -2
  20. package/dist/ui/report.zod.d.ts +4 -32
  21. package/dist/ui/report.zod.d.ts.map +1 -1
  22. package/dist/ui/report.zod.js +3 -8
  23. package/json-schema/AccountLinkingConfig.json +27 -0
  24. package/json-schema/AuthConfig.json +606 -0
  25. package/json-schema/AuthPluginConfig.json +28 -0
  26. package/json-schema/AuthStrategy.json +17 -0
  27. package/json-schema/AuthenticationConfig.json +601 -0
  28. package/json-schema/AuthenticationProvider.json +617 -0
  29. package/json-schema/CSRFConfig.json +31 -0
  30. package/json-schema/ComparisonOperator.json +56 -0
  31. package/json-schema/Dashboard.json +20 -0
  32. package/json-schema/DashboardWidget.json +20 -0
  33. package/json-schema/DatabaseAdapter.json +38 -0
  34. package/json-schema/Datasource.json +25 -5
  35. package/json-schema/DatasourceCapabilities.json +25 -5
  36. package/json-schema/DriverCapabilities.json +30 -0
  37. package/json-schema/DriverDefinition.json +25 -5
  38. package/json-schema/DriverInterface.json +30 -0
  39. package/json-schema/EmailPasswordConfig.json +43 -0
  40. package/json-schema/EqualityOperator.json +14 -0
  41. package/json-schema/FieldOperators.json +108 -0
  42. package/json-schema/FilterCondition.json +28 -0
  43. package/json-schema/MagicLinkConfig.json +21 -0
  44. package/json-schema/NormalizedFilter.json +348 -0
  45. package/json-schema/OAuthProvider.json +66 -0
  46. package/json-schema/PasskeyConfig.json +54 -0
  47. package/json-schema/QueryFilter.json +34 -0
  48. package/json-schema/RangeOperator.json +41 -0
  49. package/json-schema/RateLimitConfig.json +36 -0
  50. package/json-schema/Report.json +20 -26
  51. package/json-schema/SessionConfig.json +56 -0
  52. package/json-schema/SetOperator.json +18 -0
  53. package/json-schema/SpecialOperator.json +18 -0
  54. package/json-schema/StandardAuthProvider.json +622 -0
  55. package/json-schema/StringOperator.json +21 -0
  56. package/json-schema/TwoFactorConfig.json +40 -0
  57. package/json-schema/UserFieldMapping.json +47 -0
  58. package/package.json +1 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.zod.d.ts","sourceRoot":"","sources":["../../src/system/auth.zod.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,365 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.StandardAuthProviderSchema = exports.AuthConfigSchema = exports.AuthPluginConfigSchema = exports.DatabaseAdapterSchema = exports.UserFieldMappingSchema = exports.TwoFactorConfigSchema = exports.AccountLinkingConfigSchema = exports.CSRFConfigSchema = exports.RateLimitConfigSchema = exports.SessionConfigSchema = exports.PasskeyConfigSchema = exports.MagicLinkConfigSchema = exports.EmailPasswordConfigSchema = exports.OAuthProviderSchema = exports.AuthStrategy = void 0;
4
+ const zod_1 = require("zod");
5
+ /**
6
+ * Authentication Protocol
7
+ *
8
+ * Defines the standard authentication specification for the ObjectStack ecosystem.
9
+ * This protocol supports multiple authentication strategies, session management,
10
+ * and comprehensive security features.
11
+ *
12
+ * This is a framework-agnostic specification that can be implemented with any
13
+ * authentication library (better-auth, Auth.js, Passport, etc.)
14
+ */
15
+ /**
16
+ * Supported authentication strategies
17
+ */
18
+ exports.AuthStrategy = zod_1.z.enum([
19
+ 'email_password', // Traditional email & password authentication
20
+ 'magic_link', // Passwordless email magic link
21
+ 'oauth', // OAuth2 providers (Google, GitHub, etc.)
22
+ 'passkey', // WebAuthn / FIDO2 passkeys
23
+ 'otp', // One-time password (SMS, Email)
24
+ 'anonymous', // Anonymous/guest sessions
25
+ ]);
26
+ /**
27
+ * OAuth Provider Configuration
28
+ * Supports popular OAuth2 providers
29
+ */
30
+ exports.OAuthProviderSchema = zod_1.z.object({
31
+ provider: zod_1.z.enum([
32
+ 'google',
33
+ 'github',
34
+ 'facebook',
35
+ 'twitter',
36
+ 'linkedin',
37
+ 'microsoft',
38
+ 'apple',
39
+ 'discord',
40
+ 'gitlab',
41
+ 'custom',
42
+ ]).describe('OAuth provider type'),
43
+ clientId: zod_1.z.string().describe('OAuth client ID'),
44
+ clientSecret: zod_1.z.string().describe('OAuth client secret (typically from ENV)'),
45
+ scopes: zod_1.z.array(zod_1.z.string()).optional().describe('Requested OAuth scopes'),
46
+ redirectUri: zod_1.z.string().url().optional().describe('OAuth callback URL'),
47
+ enabled: zod_1.z.boolean().default(true).describe('Whether this provider is enabled'),
48
+ displayName: zod_1.z.string().optional().describe('Display name for the provider button'),
49
+ icon: zod_1.z.string().optional().describe('Icon URL or identifier'),
50
+ });
51
+ /**
52
+ * Email & Password Strategy Configuration
53
+ */
54
+ exports.EmailPasswordConfigSchema = zod_1.z.object({
55
+ enabled: zod_1.z.boolean().default(true),
56
+ requireEmailVerification: zod_1.z.boolean().default(true).describe('Require email verification before login'),
57
+ minPasswordLength: zod_1.z.number().min(6).max(128).default(8).describe('Minimum password length'),
58
+ requirePasswordComplexity: zod_1.z.boolean().default(true).describe('Require uppercase, lowercase, numbers, symbols'),
59
+ allowPasswordReset: zod_1.z.boolean().default(true).describe('Enable password reset functionality'),
60
+ passwordResetExpiry: zod_1.z.number().default(3600).describe('Password reset token expiry in seconds'),
61
+ });
62
+ /**
63
+ * Magic Link Strategy Configuration
64
+ */
65
+ exports.MagicLinkConfigSchema = zod_1.z.object({
66
+ enabled: zod_1.z.boolean().default(true),
67
+ expiryTime: zod_1.z.number().default(900).describe('Magic link expiry time in seconds (default 15 min)'),
68
+ sendEmail: zod_1.z.function()
69
+ .args(zod_1.z.object({
70
+ to: zod_1.z.string().email(),
71
+ link: zod_1.z.string().url(),
72
+ token: zod_1.z.string(),
73
+ }))
74
+ .returns(zod_1.z.promise(zod_1.z.void()))
75
+ .optional()
76
+ .describe('Custom email sending function'),
77
+ });
78
+ /**
79
+ * Passkey (WebAuthn) Strategy Configuration
80
+ */
81
+ exports.PasskeyConfigSchema = zod_1.z.object({
82
+ enabled: zod_1.z.boolean().default(false),
83
+ rpName: zod_1.z.string().describe('Relying Party name'),
84
+ rpId: zod_1.z.string().optional().describe('Relying Party ID (defaults to domain)'),
85
+ allowedOrigins: zod_1.z.array(zod_1.z.string().url()).optional().describe('Allowed origins for WebAuthn'),
86
+ userVerification: zod_1.z.enum(['required', 'preferred', 'discouraged']).default('preferred'),
87
+ attestation: zod_1.z.enum(['none', 'indirect', 'direct', 'enterprise']).default('none'),
88
+ });
89
+ /**
90
+ * Session Configuration
91
+ */
92
+ exports.SessionConfigSchema = zod_1.z.object({
93
+ expiresIn: zod_1.z.number().default(86400 * 7).describe('Session expiry in seconds (default 7 days)'),
94
+ updateAge: zod_1.z.number().default(86400).describe('Session update interval in seconds (default 1 day)'),
95
+ cookieName: zod_1.z.string().default('session_token').describe('Session cookie name'),
96
+ cookieSecure: zod_1.z.boolean().default(true).describe('Use secure cookies (HTTPS only)'),
97
+ cookieSameSite: zod_1.z.enum(['strict', 'lax', 'none']).default('lax').describe('SameSite cookie attribute'),
98
+ cookieDomain: zod_1.z.string().optional().describe('Cookie domain'),
99
+ cookiePath: zod_1.z.string().default('/').describe('Cookie path'),
100
+ cookieHttpOnly: zod_1.z.boolean().default(true).describe('HttpOnly cookie attribute'),
101
+ });
102
+ /**
103
+ * Rate Limiting Configuration
104
+ */
105
+ exports.RateLimitConfigSchema = zod_1.z.object({
106
+ enabled: zod_1.z.boolean().default(true),
107
+ maxAttempts: zod_1.z.number().default(5).describe('Maximum login attempts'),
108
+ windowMs: zod_1.z.number().default(900000).describe('Time window in milliseconds (default 15 min)'),
109
+ blockDuration: zod_1.z.number().default(900000).describe('Block duration after max attempts in ms'),
110
+ skipSuccessfulRequests: zod_1.z.boolean().default(false).describe('Only count failed requests'),
111
+ });
112
+ /**
113
+ * CSRF Protection Configuration
114
+ */
115
+ exports.CSRFConfigSchema = zod_1.z.object({
116
+ enabled: zod_1.z.boolean().default(true),
117
+ tokenLength: zod_1.z.number().default(32).describe('CSRF token length'),
118
+ cookieName: zod_1.z.string().default('csrf_token').describe('CSRF cookie name'),
119
+ headerName: zod_1.z.string().default('X-CSRF-Token').describe('CSRF header name'),
120
+ });
121
+ /**
122
+ * Account Linking Configuration
123
+ * Allows linking multiple auth methods to a single user account
124
+ */
125
+ exports.AccountLinkingConfigSchema = zod_1.z.object({
126
+ enabled: zod_1.z.boolean().default(true).describe('Allow account linking'),
127
+ autoLink: zod_1.z.boolean().default(false).describe('Automatically link accounts with same email'),
128
+ requireVerification: zod_1.z.boolean().default(true).describe('Require email verification before linking'),
129
+ });
130
+ /**
131
+ * Two-Factor Authentication (2FA) Configuration
132
+ */
133
+ exports.TwoFactorConfigSchema = zod_1.z.object({
134
+ enabled: zod_1.z.boolean().default(false),
135
+ issuer: zod_1.z.string().optional().describe('TOTP issuer name'),
136
+ qrCodeSize: zod_1.z.number().default(200).describe('QR code size in pixels'),
137
+ backupCodes: zod_1.z.object({
138
+ enabled: zod_1.z.boolean().default(true),
139
+ count: zod_1.z.number().default(10).describe('Number of backup codes to generate'),
140
+ }).optional(),
141
+ });
142
+ /**
143
+ * User Field Mapping Configuration
144
+ * Maps authentication user fields to ObjectStack user object fields
145
+ */
146
+ exports.UserFieldMappingSchema = zod_1.z.object({
147
+ id: zod_1.z.string().default('id').describe('User ID field'),
148
+ email: zod_1.z.string().default('email').describe('Email field'),
149
+ name: zod_1.z.string().default('name').describe('Name field'),
150
+ image: zod_1.z.string().default('image').optional().describe('Profile image field'),
151
+ emailVerified: zod_1.z.string().default('email_verified').describe('Email verification status field'),
152
+ createdAt: zod_1.z.string().default('created_at').describe('Created timestamp field'),
153
+ updatedAt: zod_1.z.string().default('updated_at').describe('Updated timestamp field'),
154
+ });
155
+ /**
156
+ * Database Adapter Configuration
157
+ */
158
+ exports.DatabaseAdapterSchema = zod_1.z.object({
159
+ type: zod_1.z.enum(['prisma', 'drizzle', 'kysely', 'custom']).describe('Database adapter type'),
160
+ connectionString: zod_1.z.string().optional().describe('Database connection string'),
161
+ tablePrefix: zod_1.z.string().default('auth_').describe('Prefix for auth tables'),
162
+ schema: zod_1.z.string().optional().describe('Database schema name'),
163
+ });
164
+ /**
165
+ * Authentication Plugin Configuration
166
+ * Extends authentication with additional features
167
+ */
168
+ exports.AuthPluginConfigSchema = zod_1.z.object({
169
+ name: zod_1.z.string().describe('Plugin name'),
170
+ enabled: zod_1.z.boolean().default(true),
171
+ options: zod_1.z.record(zod_1.z.any()).optional().describe('Plugin-specific options'),
172
+ });
173
+ /**
174
+ * Complete Authentication Configuration Schema
175
+ *
176
+ * This is the main configuration object for authentication
177
+ * in an ObjectStack application.
178
+ *
179
+ * @example
180
+ * ```typescript
181
+ * const authConfig: AuthConfig = {
182
+ * name: 'main_auth',
183
+ * label: 'Main Authentication',
184
+ * strategies: ['email_password', 'oauth'],
185
+ * baseUrl: 'https://app.example.com',
186
+ * secret: process.env.AUTH_SECRET,
187
+ * driver: 'better-auth', // Optional, defaults to 'better-auth'
188
+ * emailPassword: {
189
+ * enabled: true,
190
+ * minPasswordLength: 8,
191
+ * },
192
+ * oauth: {
193
+ * providers: [{
194
+ * provider: 'google',
195
+ * clientId: process.env.GOOGLE_CLIENT_ID,
196
+ * clientSecret: process.env.GOOGLE_CLIENT_SECRET,
197
+ * }],
198
+ * },
199
+ * session: {
200
+ * expiresIn: 604800, // 7 days
201
+ * },
202
+ * };
203
+ * ```
204
+ */
205
+ exports.AuthConfigSchema = zod_1.z.object({
206
+ /**
207
+ * Unique identifier for this auth configuration
208
+ * Must be in snake_case following ObjectStack conventions
209
+ */
210
+ name: zod_1.z.string()
211
+ .regex(/^[a-z_][a-z0-9_]*$/)
212
+ .describe('Configuration name (snake_case)'),
213
+ /**
214
+ * Human-readable label
215
+ */
216
+ label: zod_1.z.string().describe('Display label'),
217
+ /**
218
+ * The underlying authentication implementation driver
219
+ * Default: 'better-auth' (the reference implementation)
220
+ * Can be: 'better-auth', 'auth-js', 'passport', or custom driver name
221
+ */
222
+ driver: zod_1.z.string().default('better-auth').describe('The underlying authentication implementation driver'),
223
+ /**
224
+ * Enabled authentication strategies
225
+ */
226
+ strategies: zod_1.z.array(exports.AuthStrategy).min(1).describe('Enabled authentication strategies'),
227
+ /**
228
+ * Base URL for the application
229
+ */
230
+ baseUrl: zod_1.z.string().url().describe('Application base URL'),
231
+ /**
232
+ * Secret key for signing tokens and cookies
233
+ * Should be loaded from environment variables
234
+ */
235
+ secret: zod_1.z.string().min(32).describe('Secret key for signing (min 32 chars)'),
236
+ /**
237
+ * Email & Password configuration
238
+ */
239
+ emailPassword: exports.EmailPasswordConfigSchema.optional(),
240
+ /**
241
+ * Magic Link configuration
242
+ */
243
+ magicLink: exports.MagicLinkConfigSchema.optional(),
244
+ /**
245
+ * Passkey (WebAuthn) configuration
246
+ */
247
+ passkey: exports.PasskeyConfigSchema.optional(),
248
+ /**
249
+ * OAuth configuration
250
+ */
251
+ oauth: zod_1.z.object({
252
+ providers: zod_1.z.array(exports.OAuthProviderSchema).min(1),
253
+ }).optional(),
254
+ /**
255
+ * Session configuration
256
+ */
257
+ session: exports.SessionConfigSchema.default({}),
258
+ /**
259
+ * Rate limiting configuration
260
+ */
261
+ rateLimit: exports.RateLimitConfigSchema.default({}),
262
+ /**
263
+ * CSRF protection configuration
264
+ */
265
+ csrf: exports.CSRFConfigSchema.default({}),
266
+ /**
267
+ * Account linking configuration
268
+ */
269
+ accountLinking: exports.AccountLinkingConfigSchema.default({}),
270
+ /**
271
+ * Two-factor authentication configuration
272
+ */
273
+ twoFactor: exports.TwoFactorConfigSchema.optional(),
274
+ /**
275
+ * User field mapping
276
+ */
277
+ userFieldMapping: exports.UserFieldMappingSchema.default({}),
278
+ /**
279
+ * Database adapter configuration
280
+ */
281
+ database: exports.DatabaseAdapterSchema.optional(),
282
+ /**
283
+ * Additional authentication plugins
284
+ */
285
+ plugins: zod_1.z.array(exports.AuthPluginConfigSchema).default([]),
286
+ /**
287
+ * Custom hooks for authentication events
288
+ */
289
+ hooks: zod_1.z.object({
290
+ beforeSignIn: zod_1.z.function()
291
+ .args(zod_1.z.object({ email: zod_1.z.string() }))
292
+ .returns(zod_1.z.promise(zod_1.z.void()))
293
+ .optional()
294
+ .describe('Called before user sign in'),
295
+ afterSignIn: zod_1.z.function()
296
+ .args(zod_1.z.object({ user: zod_1.z.any(), session: zod_1.z.any() }))
297
+ .returns(zod_1.z.promise(zod_1.z.void()))
298
+ .optional()
299
+ .describe('Called after user sign in'),
300
+ beforeSignUp: zod_1.z.function()
301
+ .args(zod_1.z.object({ email: zod_1.z.string(), name: zod_1.z.string().optional() }))
302
+ .returns(zod_1.z.promise(zod_1.z.void()))
303
+ .optional()
304
+ .describe('Called before user registration'),
305
+ afterSignUp: zod_1.z.function()
306
+ .args(zod_1.z.object({ user: zod_1.z.any() }))
307
+ .returns(zod_1.z.promise(zod_1.z.void()))
308
+ .optional()
309
+ .describe('Called after user registration'),
310
+ beforeSignOut: zod_1.z.function()
311
+ .args(zod_1.z.object({ sessionId: zod_1.z.string() }))
312
+ .returns(zod_1.z.promise(zod_1.z.void()))
313
+ .optional()
314
+ .describe('Called before user sign out'),
315
+ afterSignOut: zod_1.z.function()
316
+ .args(zod_1.z.object({ sessionId: zod_1.z.string() }))
317
+ .returns(zod_1.z.promise(zod_1.z.void()))
318
+ .optional()
319
+ .describe('Called after user sign out'),
320
+ }).optional().describe('Authentication lifecycle hooks'),
321
+ /**
322
+ * Advanced security settings
323
+ */
324
+ security: zod_1.z.object({
325
+ allowedOrigins: zod_1.z.array(zod_1.z.string()).optional().describe('CORS allowed origins'),
326
+ trustProxy: zod_1.z.boolean().default(false).describe('Trust proxy headers'),
327
+ ipRateLimiting: zod_1.z.boolean().default(true).describe('Enable IP-based rate limiting'),
328
+ sessionFingerprinting: zod_1.z.boolean().default(true).describe('Enable session fingerprinting'),
329
+ maxSessions: zod_1.z.number().default(5).describe('Maximum concurrent sessions per user'),
330
+ }).optional().describe('Advanced security settings'),
331
+ /**
332
+ * Email configuration for transactional emails
333
+ */
334
+ email: zod_1.z.object({
335
+ from: zod_1.z.string().email().describe('From email address'),
336
+ fromName: zod_1.z.string().optional().describe('From name'),
337
+ provider: zod_1.z.enum(['smtp', 'sendgrid', 'mailgun', 'ses', 'resend', 'custom']).describe('Email provider'),
338
+ config: zod_1.z.record(zod_1.z.any()).optional().describe('Provider-specific configuration'),
339
+ }).optional().describe('Email configuration'),
340
+ /**
341
+ * UI customization options
342
+ */
343
+ ui: zod_1.z.object({
344
+ brandName: zod_1.z.string().optional().describe('Brand name displayed in auth UI'),
345
+ logo: zod_1.z.string().optional().describe('Logo URL'),
346
+ primaryColor: zod_1.z.string().optional().describe('Primary brand color (hex)'),
347
+ customCss: zod_1.z.string().optional().describe('Custom CSS for auth pages'),
348
+ }).optional().describe('UI customization'),
349
+ /**
350
+ * Whether this auth provider is active
351
+ */
352
+ active: zod_1.z.boolean().default(true).describe('Whether this provider is active'),
353
+ /**
354
+ * Whether to allow new user registration
355
+ */
356
+ allowRegistration: zod_1.z.boolean().default(true).describe('Allow new user registration'),
357
+ });
358
+ /**
359
+ * Standard Authentication Provider Schema
360
+ * Wraps the configuration for use in the identity system
361
+ */
362
+ exports.StandardAuthProviderSchema = zod_1.z.object({
363
+ type: zod_1.z.literal('standard_auth').describe('Provider type identifier'),
364
+ config: exports.AuthConfigSchema.describe('Standard authentication configuration'),
365
+ });
@@ -31,32 +31,52 @@ export declare const DriverDefinitionSchema: z.ZodObject<{
31
31
  * What this driver supports out-of-the-box.
32
32
  */
33
33
  capabilities: z.ZodOptional<z.ZodLazy<z.ZodObject<{
34
- /** Can execute SQL-like joins natively? */
35
- joins: z.ZodDefault<z.ZodBoolean>;
36
34
  /** Can handle ACID transactions? */
37
35
  transactions: z.ZodDefault<z.ZodBoolean>;
36
+ /** Can execute WHERE clause filters natively? */
37
+ queryFilters: z.ZodDefault<z.ZodBoolean>;
38
+ /** Can perform aggregation (group by, sum, avg)? */
39
+ queryAggregations: z.ZodDefault<z.ZodBoolean>;
40
+ /** Can perform ORDER BY sorting? */
41
+ querySorting: z.ZodDefault<z.ZodBoolean>;
42
+ /** Can perform LIMIT/OFFSET pagination? */
43
+ queryPagination: z.ZodDefault<z.ZodBoolean>;
44
+ /** Can perform window functions? */
45
+ queryWindowFunctions: z.ZodDefault<z.ZodBoolean>;
46
+ /** Can perform subqueries? */
47
+ querySubqueries: z.ZodDefault<z.ZodBoolean>;
48
+ /** Can execute SQL-like joins natively? */
49
+ joins: z.ZodDefault<z.ZodBoolean>;
38
50
  /** Can perform full-text search? */
39
51
  fullTextSearch: z.ZodDefault<z.ZodBoolean>;
40
- /** Can perform aggregation (group by, sum, avg)? */
41
- aggregation: z.ZodDefault<z.ZodBoolean>;
42
- /** Is scheme-less (needs schema inference)? */
43
- dynamicSchema: z.ZodDefault<z.ZodBoolean>;
44
52
  /** Is read-only? */
45
53
  readOnly: z.ZodDefault<z.ZodBoolean>;
54
+ /** Is scheme-less (needs schema inference)? */
55
+ dynamicSchema: z.ZodDefault<z.ZodBoolean>;
46
56
  }, "strip", z.ZodTypeAny, {
47
57
  joins: boolean;
48
58
  transactions: boolean;
59
+ queryFilters: boolean;
60
+ queryAggregations: boolean;
61
+ querySorting: boolean;
62
+ queryPagination: boolean;
63
+ queryWindowFunctions: boolean;
64
+ querySubqueries: boolean;
49
65
  fullTextSearch: boolean;
50
- aggregation: boolean;
51
- dynamicSchema: boolean;
52
66
  readOnly: boolean;
67
+ dynamicSchema: boolean;
53
68
  }, {
54
69
  joins?: boolean | undefined;
55
70
  transactions?: boolean | undefined;
71
+ queryFilters?: boolean | undefined;
72
+ queryAggregations?: boolean | undefined;
73
+ querySorting?: boolean | undefined;
74
+ queryPagination?: boolean | undefined;
75
+ queryWindowFunctions?: boolean | undefined;
76
+ querySubqueries?: boolean | undefined;
56
77
  fullTextSearch?: boolean | undefined;
57
- aggregation?: boolean | undefined;
58
- dynamicSchema?: boolean | undefined;
59
78
  readOnly?: boolean | undefined;
79
+ dynamicSchema?: boolean | undefined;
60
80
  }>>>;
61
81
  }, "strip", z.ZodTypeAny, {
62
82
  label: string;
@@ -67,10 +87,15 @@ export declare const DriverDefinitionSchema: z.ZodObject<{
67
87
  capabilities?: {
68
88
  joins: boolean;
69
89
  transactions: boolean;
90
+ queryFilters: boolean;
91
+ queryAggregations: boolean;
92
+ querySorting: boolean;
93
+ queryPagination: boolean;
94
+ queryWindowFunctions: boolean;
95
+ querySubqueries: boolean;
70
96
  fullTextSearch: boolean;
71
- aggregation: boolean;
72
- dynamicSchema: boolean;
73
97
  readOnly: boolean;
98
+ dynamicSchema: boolean;
74
99
  } | undefined;
75
100
  }, {
76
101
  label: string;
@@ -81,10 +106,15 @@ export declare const DriverDefinitionSchema: z.ZodObject<{
81
106
  capabilities?: {
82
107
  joins?: boolean | undefined;
83
108
  transactions?: boolean | undefined;
109
+ queryFilters?: boolean | undefined;
110
+ queryAggregations?: boolean | undefined;
111
+ querySorting?: boolean | undefined;
112
+ queryPagination?: boolean | undefined;
113
+ queryWindowFunctions?: boolean | undefined;
114
+ querySubqueries?: boolean | undefined;
84
115
  fullTextSearch?: boolean | undefined;
85
- aggregation?: boolean | undefined;
86
- dynamicSchema?: boolean | undefined;
87
116
  readOnly?: boolean | undefined;
117
+ dynamicSchema?: boolean | undefined;
88
118
  } | undefined;
89
119
  }>;
90
120
  /**
@@ -94,32 +124,52 @@ export declare const DriverDefinitionSchema: z.ZodObject<{
94
124
  * and what to compute in memory.
95
125
  */
96
126
  export declare const DatasourceCapabilities: z.ZodObject<{
97
- /** Can execute SQL-like joins natively? */
98
- joins: z.ZodDefault<z.ZodBoolean>;
99
127
  /** Can handle ACID transactions? */
100
128
  transactions: z.ZodDefault<z.ZodBoolean>;
129
+ /** Can execute WHERE clause filters natively? */
130
+ queryFilters: z.ZodDefault<z.ZodBoolean>;
131
+ /** Can perform aggregation (group by, sum, avg)? */
132
+ queryAggregations: z.ZodDefault<z.ZodBoolean>;
133
+ /** Can perform ORDER BY sorting? */
134
+ querySorting: z.ZodDefault<z.ZodBoolean>;
135
+ /** Can perform LIMIT/OFFSET pagination? */
136
+ queryPagination: z.ZodDefault<z.ZodBoolean>;
137
+ /** Can perform window functions? */
138
+ queryWindowFunctions: z.ZodDefault<z.ZodBoolean>;
139
+ /** Can perform subqueries? */
140
+ querySubqueries: z.ZodDefault<z.ZodBoolean>;
141
+ /** Can execute SQL-like joins natively? */
142
+ joins: z.ZodDefault<z.ZodBoolean>;
101
143
  /** Can perform full-text search? */
102
144
  fullTextSearch: z.ZodDefault<z.ZodBoolean>;
103
- /** Can perform aggregation (group by, sum, avg)? */
104
- aggregation: z.ZodDefault<z.ZodBoolean>;
105
- /** Is scheme-less (needs schema inference)? */
106
- dynamicSchema: z.ZodDefault<z.ZodBoolean>;
107
145
  /** Is read-only? */
108
146
  readOnly: z.ZodDefault<z.ZodBoolean>;
147
+ /** Is scheme-less (needs schema inference)? */
148
+ dynamicSchema: z.ZodDefault<z.ZodBoolean>;
109
149
  }, "strip", z.ZodTypeAny, {
110
150
  joins: boolean;
111
151
  transactions: boolean;
152
+ queryFilters: boolean;
153
+ queryAggregations: boolean;
154
+ querySorting: boolean;
155
+ queryPagination: boolean;
156
+ queryWindowFunctions: boolean;
157
+ querySubqueries: boolean;
112
158
  fullTextSearch: boolean;
113
- aggregation: boolean;
114
- dynamicSchema: boolean;
115
159
  readOnly: boolean;
160
+ dynamicSchema: boolean;
116
161
  }, {
117
162
  joins?: boolean | undefined;
118
163
  transactions?: boolean | undefined;
164
+ queryFilters?: boolean | undefined;
165
+ queryAggregations?: boolean | undefined;
166
+ querySorting?: boolean | undefined;
167
+ queryPagination?: boolean | undefined;
168
+ queryWindowFunctions?: boolean | undefined;
169
+ querySubqueries?: boolean | undefined;
119
170
  fullTextSearch?: boolean | undefined;
120
- aggregation?: boolean | undefined;
121
- dynamicSchema?: boolean | undefined;
122
171
  readOnly?: boolean | undefined;
172
+ dynamicSchema?: boolean | undefined;
123
173
  }>;
124
174
  /**
125
175
  * Datasource Schema
@@ -143,32 +193,52 @@ export declare const DatasourceSchema: z.ZodObject<{
143
193
  * Manually override what the driver claims to support.
144
194
  */
145
195
  capabilities: z.ZodOptional<z.ZodObject<{
146
- /** Can execute SQL-like joins natively? */
147
- joins: z.ZodDefault<z.ZodBoolean>;
148
196
  /** Can handle ACID transactions? */
149
197
  transactions: z.ZodDefault<z.ZodBoolean>;
198
+ /** Can execute WHERE clause filters natively? */
199
+ queryFilters: z.ZodDefault<z.ZodBoolean>;
200
+ /** Can perform aggregation (group by, sum, avg)? */
201
+ queryAggregations: z.ZodDefault<z.ZodBoolean>;
202
+ /** Can perform ORDER BY sorting? */
203
+ querySorting: z.ZodDefault<z.ZodBoolean>;
204
+ /** Can perform LIMIT/OFFSET pagination? */
205
+ queryPagination: z.ZodDefault<z.ZodBoolean>;
206
+ /** Can perform window functions? */
207
+ queryWindowFunctions: z.ZodDefault<z.ZodBoolean>;
208
+ /** Can perform subqueries? */
209
+ querySubqueries: z.ZodDefault<z.ZodBoolean>;
210
+ /** Can execute SQL-like joins natively? */
211
+ joins: z.ZodDefault<z.ZodBoolean>;
150
212
  /** Can perform full-text search? */
151
213
  fullTextSearch: z.ZodDefault<z.ZodBoolean>;
152
- /** Can perform aggregation (group by, sum, avg)? */
153
- aggregation: z.ZodDefault<z.ZodBoolean>;
154
- /** Is scheme-less (needs schema inference)? */
155
- dynamicSchema: z.ZodDefault<z.ZodBoolean>;
156
214
  /** Is read-only? */
157
215
  readOnly: z.ZodDefault<z.ZodBoolean>;
216
+ /** Is scheme-less (needs schema inference)? */
217
+ dynamicSchema: z.ZodDefault<z.ZodBoolean>;
158
218
  }, "strip", z.ZodTypeAny, {
159
219
  joins: boolean;
160
220
  transactions: boolean;
221
+ queryFilters: boolean;
222
+ queryAggregations: boolean;
223
+ querySorting: boolean;
224
+ queryPagination: boolean;
225
+ queryWindowFunctions: boolean;
226
+ querySubqueries: boolean;
161
227
  fullTextSearch: boolean;
162
- aggregation: boolean;
163
- dynamicSchema: boolean;
164
228
  readOnly: boolean;
229
+ dynamicSchema: boolean;
165
230
  }, {
166
231
  joins?: boolean | undefined;
167
232
  transactions?: boolean | undefined;
233
+ queryFilters?: boolean | undefined;
234
+ queryAggregations?: boolean | undefined;
235
+ querySorting?: boolean | undefined;
236
+ queryPagination?: boolean | undefined;
237
+ queryWindowFunctions?: boolean | undefined;
238
+ querySubqueries?: boolean | undefined;
168
239
  fullTextSearch?: boolean | undefined;
169
- aggregation?: boolean | undefined;
170
- dynamicSchema?: boolean | undefined;
171
240
  readOnly?: boolean | undefined;
241
+ dynamicSchema?: boolean | undefined;
172
242
  }>>;
173
243
  /** Description */
174
244
  description: z.ZodOptional<z.ZodString>;
@@ -184,10 +254,15 @@ export declare const DatasourceSchema: z.ZodObject<{
184
254
  capabilities?: {
185
255
  joins: boolean;
186
256
  transactions: boolean;
257
+ queryFilters: boolean;
258
+ queryAggregations: boolean;
259
+ querySorting: boolean;
260
+ queryPagination: boolean;
261
+ queryWindowFunctions: boolean;
262
+ querySubqueries: boolean;
187
263
  fullTextSearch: boolean;
188
- aggregation: boolean;
189
- dynamicSchema: boolean;
190
264
  readOnly: boolean;
265
+ dynamicSchema: boolean;
191
266
  } | undefined;
192
267
  }, {
193
268
  name: string;
@@ -199,10 +274,15 @@ export declare const DatasourceSchema: z.ZodObject<{
199
274
  capabilities?: {
200
275
  joins?: boolean | undefined;
201
276
  transactions?: boolean | undefined;
277
+ queryFilters?: boolean | undefined;
278
+ queryAggregations?: boolean | undefined;
279
+ querySorting?: boolean | undefined;
280
+ queryPagination?: boolean | undefined;
281
+ queryWindowFunctions?: boolean | undefined;
282
+ querySubqueries?: boolean | undefined;
202
283
  fullTextSearch?: boolean | undefined;
203
- aggregation?: boolean | undefined;
204
- dynamicSchema?: boolean | undefined;
205
284
  readOnly?: boolean | undefined;
285
+ dynamicSchema?: boolean | undefined;
206
286
  } | undefined;
207
287
  }>;
208
288
  export type Datasource = z.infer<typeof DatasourceSchema>;
@@ -1 +1 @@
1
- {"version":3,"file":"datasource.zod.d.ts","sourceRoot":"","sources":["../../src/system/datasource.zod.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB;;;;GAIG;AACH,eAAO,MAAM,cAAc,+KAMjB,CAAC;AAEX;;;GAGG;AACH,eAAO,MAAM,UAAU,aAAsD,CAAC;AAE9E;;;;GAIG;AACH,eAAO,MAAM,sBAAsB;;;;;IAMjC;;;;OAIG;;IAGH;;;OAGG;;QAWH,2CAA2C;;QAE3C,oCAAoC;;QAEpC,oCAAoC;;QAEpC,oDAAoD;;QAEpD,+CAA+C;;QAE/C,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAnBpB,CAAC;AAEH;;;;;GAKG;AACH,eAAO,MAAM,sBAAsB;IACjC,2CAA2C;;IAE3C,oCAAoC;;IAEpC,oCAAoC;;IAEpC,oDAAoD;;IAEpD,+CAA+C;;IAE/C,oBAAoB;;;;;;;;;;;;;;;;EAEpB,CAAC;AAEH;;;GAGG;AACH,eAAO,MAAM,gBAAgB;IAC3B,mBAAmB;;IAGnB,kBAAkB;;IAGlB,aAAa;;IAGb;;;;OAIG;;IAGH;;;OAGG;;QAtCH,2CAA2C;;QAE3C,oCAAoC;;QAEpC,oCAAoC;;QAEpC,oDAAoD;;QAEpD,+CAA+C;;QAE/C,oBAAoB;;;;;;;;;;;;;;;;;IA+BpB,kBAAkB;;IAGlB,kBAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAElB,CAAC;AAEH,MAAM,MAAM,UAAU,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,gBAAgB,CAAC,CAAC;AAC1D,MAAM,MAAM,gBAAgB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,sBAAsB,CAAC,CAAC"}
1
+ {"version":3,"file":"datasource.zod.d.ts","sourceRoot":"","sources":["../../src/system/datasource.zod.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB;;;;GAIG;AACH,eAAO,MAAM,cAAc,+KAMjB,CAAC;AAEX;;;GAGG;AACH,eAAO,MAAM,UAAU,aAAsD,CAAC;AAE9E;;;;GAIG;AACH,eAAO,MAAM,sBAAsB;;;;;IAMjC;;;;OAIG;;IAGH;;;OAGG;;QAeH,oCAAoC;;QAOpC,iDAAiD;;QAGjD,oDAAoD;;QAGpD,oCAAoC;;QAGpC,2CAA2C;;QAG3C,oCAAoC;;QAGpC,8BAA8B;;QAG9B,2CAA2C;;QAO3C,oCAAoC;;QAGpC,oBAAoB;;QAGpB,+CAA+C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAnD/C,CAAC;AAEH;;;;;GAKG;AACH,eAAO,MAAM,sBAAsB;IAKjC,oCAAoC;;IAOpC,iDAAiD;;IAGjD,oDAAoD;;IAGpD,oCAAoC;;IAGpC,2CAA2C;;IAG3C,oCAAoC;;IAGpC,8BAA8B;;IAG9B,2CAA2C;;IAO3C,oCAAoC;;IAGpC,oBAAoB;;IAGpB,+CAA+C;;;;;;;;;;;;;;;;;;;;;;;;;;EAE/C,CAAC;AAEH;;;GAGG;AACH,eAAO,MAAM,gBAAgB;IAC3B,mBAAmB;;IAGnB,kBAAkB;;IAGlB,aAAa;;IAGb;;;;OAIG;;IAGH;;;OAGG;;QAlEH,oCAAoC;;QAOpC,iDAAiD;;QAGjD,oDAAoD;;QAGpD,oCAAoC;;QAGpC,2CAA2C;;QAG3C,oCAAoC;;QAGpC,8BAA8B;;QAG9B,2CAA2C;;QAO3C,oCAAoC;;QAGpC,oBAAoB;;QAGpB,+CAA+C;;;;;;;;;;;;;;;;;;;;;;;;;;;IA+B/C,kBAAkB;;IAGlB,kBAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAElB,CAAC;AAEH,MAAM,MAAM,UAAU,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,gBAAgB,CAAC,CAAC;AAC1D,MAAM,MAAM,gBAAgB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,sBAAsB,CAAC,CAAC"}