velocious 1.0.290 → 1.0.292
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/README.md +2 -0
- package/build/src/configuration-types.d.ts +2 -27
- package/build/src/configuration-types.d.ts.map +1 -1
- package/build/src/configuration-types.js +2 -5
- package/build/src/database/table-data/table-column.d.ts +5 -0
- package/build/src/database/table-data/table-column.d.ts.map +1 -1
- package/build/src/database/table-data/table-column.js +10 -2
- package/build/src/environment-handlers/node.js +2 -2
- package/build/src/frontend-model-controller.js +2 -2
- package/build/src/frontend-models/base.d.ts +4 -0
- package/build/src/frontend-models/base.d.ts.map +1 -1
- package/build/src/frontend-models/base.js +32 -3
- package/build/src/frontend-models/resource-definition.d.ts.map +1 -1
- package/build/src/frontend-models/resource-definition.js +2 -40
- package/build/src/frontend-models/websocket-publishers.d.ts.map +1 -1
- package/build/src/frontend-models/websocket-publishers.js +8 -21
- package/build/src/http-server/development-reloader.d.ts +94 -0
- package/build/src/http-server/development-reloader.d.ts.map +1 -0
- package/build/src/http-server/development-reloader.js +180 -0
- package/build/src/http-server/index.d.ts +35 -1
- package/build/src/http-server/index.d.ts.map +1 -1
- package/build/src/http-server/index.js +58 -3
- package/build/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -1610,6 +1610,8 @@ If a handed-off job does not report back within 2 hours, it is marked orphaned a
|
|
|
1610
1610
|
npx velocious server --host 0.0.0.0 --port 8082
|
|
1611
1611
|
```
|
|
1612
1612
|
|
|
1613
|
+
When the server runs in the `development` environment, Velocious watches application `src/` trees and hot-reloads by recycling HTTP workers after `.js`/`.mjs`/`.cjs`/`.json`/`.ejs` changes. That picks up edited controllers, models, resources, routes, and views without a manual server restart while keeping production/test behavior unchanged.
|
|
1614
|
+
|
|
1613
1615
|
# Authorization (CanCan-style)
|
|
1614
1616
|
|
|
1615
1617
|
Define resource classes with an `abilities()` method and use `can` / `cannot` rules to constrain model access.
|
|
@@ -219,10 +219,7 @@
|
|
|
219
219
|
* @typedef {object} BackendProjectConfiguration
|
|
220
220
|
* @property {string} path - Path to the backend project.
|
|
221
221
|
* @property {string} [frontendModelsOutputPath] - Optional output project path where `src/frontend-models` should be generated.
|
|
222
|
-
* @property {Record<string, FrontendModelResourceDefinition>} [frontendModels] -
|
|
223
|
-
* @property {{(id: string): {default?: unknown}, keys: () => string[]}} [frontendModelsRequireContext] - Webpack-style require context for frontend model resource files.
|
|
224
|
-
* @property {Record<string, FrontendModelResourceDefinition>} [resources] - Alias for `frontendModels`.
|
|
225
|
-
* @property {{(id: string): {default?: unknown}, keys: () => string[]}} [resourcesRequireContext] - Alias for `frontendModelsRequireContext`.
|
|
222
|
+
* @property {Record<string, FrontendModelResourceDefinition>} [frontendModels] - Auto-discovered frontend model definitions keyed by model class name. Set internally by the environment handler — do not set manually.
|
|
226
223
|
*/
|
|
227
224
|
/**
|
|
228
225
|
* @typedef {object} RouteResolverHookArgs
|
|
@@ -875,31 +872,9 @@ export type BackendProjectConfiguration = {
|
|
|
875
872
|
*/
|
|
876
873
|
frontendModelsOutputPath?: string | undefined;
|
|
877
874
|
/**
|
|
878
|
-
* -
|
|
875
|
+
* - Auto-discovered frontend model definitions keyed by model class name. Set internally by the environment handler — do not set manually.
|
|
879
876
|
*/
|
|
880
877
|
frontendModels?: Record<string, typeof import("./frontend-model-resource/base-resource.js").default> | undefined;
|
|
881
|
-
/**
|
|
882
|
-
* - Webpack-style require context for frontend model resource files.
|
|
883
|
-
*/
|
|
884
|
-
frontendModelsRequireContext?: {
|
|
885
|
-
(id: string): {
|
|
886
|
-
default?: unknown;
|
|
887
|
-
};
|
|
888
|
-
keys: () => string[];
|
|
889
|
-
} | undefined;
|
|
890
|
-
/**
|
|
891
|
-
* - Alias for `frontendModels`.
|
|
892
|
-
*/
|
|
893
|
-
resources?: Record<string, typeof import("./frontend-model-resource/base-resource.js").default> | undefined;
|
|
894
|
-
/**
|
|
895
|
-
* - Alias for `frontendModelsRequireContext`.
|
|
896
|
-
*/
|
|
897
|
-
resourcesRequireContext?: {
|
|
898
|
-
(id: string): {
|
|
899
|
-
default?: unknown;
|
|
900
|
-
};
|
|
901
|
-
keys: () => string[];
|
|
902
|
-
} | undefined;
|
|
903
878
|
};
|
|
904
879
|
export type RouteResolverHookArgs = {
|
|
905
880
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"configuration-types.d.ts","sourceRoot":"","sources":["../../src/configuration-types.js"],"names":[],"mappings":"AAEA;;GAEG;AAEH;;GAEG;AAEH;;GAEG;AAEH;;;;;;GAMG;AAEH;;GAEG;AAEH;;;;;;;;GAQG;AAEH;;;;;;;;;;;;;;;GAeG;AAEH;;;;;;;;;;;;;;;;;;;;;GAqBG;AAEH;;GAEG;AAEH;;;;;;GAMG;AAEH;;;;GAIG;AAEH;;;;GAIG;AAEH;;GAEG;AAEH;;;;;;;;;;GAUG;AAEH;;;GAGG;AAEH;;;;;GAKG;AAEH;;;;GAIG;AAEH;;;;;;;GAOG;AAEH;;;GAGG;AAEH;;GAEG;AAEH;;;;;GAKG;AAEH;;;;;;GAMG;AAEH;;;GAGG;AAGH;;GAEG;AAEH;;;;;;GAMG;AAEH;;;;;;;GAOG;AAEH;;;GAGG;AAEH;;;;;;;;;;;;;;GAcG;AAEH;;;;;;;;GAQG;AAEH;;GAEG;AAEH;;GAEG;AAEH;;;;;;;GAOG;AAEH;;;;;;;;;GASG;AAEH
|
|
1
|
+
{"version":3,"file":"configuration-types.d.ts","sourceRoot":"","sources":["../../src/configuration-types.js"],"names":[],"mappings":"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"}
|
|
@@ -220,10 +220,7 @@
|
|
|
220
220
|
* @typedef {object} BackendProjectConfiguration
|
|
221
221
|
* @property {string} path - Path to the backend project.
|
|
222
222
|
* @property {string} [frontendModelsOutputPath] - Optional output project path where `src/frontend-models` should be generated.
|
|
223
|
-
* @property {Record<string, FrontendModelResourceDefinition>} [frontendModels] -
|
|
224
|
-
* @property {{(id: string): {default?: unknown}, keys: () => string[]}} [frontendModelsRequireContext] - Webpack-style require context for frontend model resource files.
|
|
225
|
-
* @property {Record<string, FrontendModelResourceDefinition>} [resources] - Alias for `frontendModels`.
|
|
226
|
-
* @property {{(id: string): {default?: unknown}, keys: () => string[]}} [resourcesRequireContext] - Alias for `frontendModelsRequireContext`.
|
|
223
|
+
* @property {Record<string, FrontendModelResourceDefinition>} [frontendModels] - Auto-discovered frontend model definitions keyed by model class name. Set internally by the environment handler — do not set manually.
|
|
227
224
|
*/
|
|
228
225
|
/**
|
|
229
226
|
* @typedef {object} RouteResolverHookArgs
|
|
@@ -292,4 +289,4 @@
|
|
|
292
289
|
* @property {WebsocketMessageHandlerResolverType} [websocketMessageHandlerResolver] - Resolve a raw websocket message handler for each connection.
|
|
293
290
|
*/
|
|
294
291
|
export const nothing = {};
|
|
295
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"configuration-types.js","sourceRoot":"","sources":["../../src/configuration-types.js"],"names":[],"mappings":"AAAA,YAAY;AAEZ;;GAEG;AAEH;;GAEG;AAEH;;GAEG;AAEH;;;;;;GAMG;AAEH;;GAEG;AAEH;;;;;;;;GAQG;AAEH;;;;;;;;;;;;;;;GAeG;AAEH;;;;;;;;;;;;;;;;;;;;;GAqBG;AAEH;;GAEG;AAEH;;;;;;GAMG;AAEH;;;;GAIG;AAEH;;;;GAIG;AAEH;;GAEG;AAEH;;;;;;;;;;GAUG;AAEH;;;GAGG;AAEH;;;;;GAKG;AAEH;;;;GAIG;AAEH;;;;;;;GAOG;AAEH;;;GAGG;AAEH;;GAEG;AAEH;;;;;GAKG;AAEH;;;;;;GAMG;AAEH;;;GAGG;AAGH;;GAEG;AAEH;;;;;;GAMG;AAEH;;;;;;;GAOG;AAEH;;;GAGG;AAEH;;;;;;;;;;;;;;GAcG;AAEH;;;;;;;;GAQG;AAEH;;GAEG;AAEH;;GAEG;AAEH;;;;;;;GAOG;AAEH;;;;;;;;;GASG;AAEH;;;;;;;;GAQG;AAEH;;;;;;;;;GASG;AAEH;;;;;;;;GAQG;AAEH;;GAEG;AAEH;;GAEG;AAEH;;GAEG;AAEH;;GAEG;AAEH;;GAEG;AAEH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+BG;AAEH,MAAM,CAAC,MAAM,OAAO,GAAG,EAAE,CAAA","sourcesContent":["// @ts-check\n\n/**\n * @module types\n */\n\n/**\n * @typedef {function({request: import(\"./http-server/client/request.js\").default | import(\"./http-server/client/websocket-request.js\").default, response: import(\"./http-server/client/response.js\").default}): Promise<void>} CorsType\n */\n\n/**\n * @typedef {function({request: import(\"./http-server/client/request.js\").default | import(\"./http-server/client/websocket-request.js\").default | undefined, subscription?: {channel: string, params?: Record<string, unknown>}, client: import(\"./http-server/client/index.js\").default, websocketSession: import(\"./http-server/client/websocket-session.js\").default, configuration: import(\"./configuration.js\").default}): typeof import(\"./http-server/websocket-channel.js\").default | import(\"./http-server/websocket-channel.js\").default | void | Promise<typeof import(\"./http-server/websocket-channel.js\").default | import(\"./http-server/websocket-channel.js\").default | void>} WebsocketChannelResolverType\n */\n\n/**\n * @typedef {object} WebsocketMessageHandler\n * @property {function({message: any, session: import(\"./http-server/client/websocket-session.js\").default}) : Promise<void> | void} [onMessage] - Handler for incoming websocket messages.\n * @property {function({session: import(\"./http-server/client/websocket-session.js\").default}) : Promise<void> | void} [onOpen] - Handler when the websocket session opens.\n * @property {function({session: import(\"./http-server/client/websocket-session.js\").default}) : Promise<void> | void} [onClose] - Handler when the websocket session closes.\n * @property {function({error: Error, session: import(\"./http-server/client/websocket-session.js\").default}) : Promise<void> | void} [onError] - Handler when a websocket message errors.\n */\n\n/**\n * @typedef {function({request: import(\"./http-server/client/request.js\").default | import(\"./http-server/client/websocket-request.js\").default | undefined, client: import(\"./http-server/client/index.js\").default, configuration: import(\"./configuration.js\").default}): WebsocketMessageHandler | void | Promise<WebsocketMessageHandler | void>} WebsocketMessageHandlerResolverType\n */\n\n/**\n * @typedef {(id: string) => {default: typeof import(\"./initializer.js\").default}} InitializersRequireContextType\n * @typedef {InitializersRequireContextType & {\n *   keys: () => string[],\n *   id: string\n * }} WebpackRequireContext\n * @typedef {{requireContext: WebpackRequireContext}} InitializersExportType\n * @typedef {function({configuration: import(\"./configuration.js\").default}) : Promise<InitializersExportType>} InitializersType\n */\n\n/**\n * @typedef {object} SqlConfig\n * @property {string} [database] - Database name for the SQL driver.\n * @property {object} [options] - Driver-specific connection options.\n * @property {boolean} [options.encrypt] - Whether to encrypt the connection (MSSQL).\n * @property {string} [options.schema] - Default schema for unqualified table lookups (MSSQL).\n * @property {string} [options.serverName] - TLS SNI server name override for MSSQL (empty string disables SNI).\n * @property {boolean} [options.trustServerCertificate] - Whether to trust the server certificate (MSSQL).\n * @property {string} [password] - Password for the SQL user.\n * @property {object} [pool] - Connection pool configuration.\n * @property {number} [pool.max] - Maximum number of connections.\n * @property {number} [pool.min] - Minimum number of connections.\n * @property {number} [pool.idleTimeoutMillis] - Idle timeout before releasing a connection.\n * @property {string} [server] - SQL server hostname.\n * @property {string} [user] - SQL username.\n */\n\n/**\n * @typedef {object} DatabaseConfigurationType\n * @property {string} [database] - Database name for this connection.\n * @property {typeof import(\"./database/drivers/base.js\").default} [driver] - Driver class to use for this database.\n * @property {typeof import(\"./database/pool/base.js\").default} [poolType] - Pool class to use for this database.\n * @property {function() : unknown} [getConnection] - Custom connection factory override.\n * @property {string} [host] - Database host.\n * @property {boolean} [migrations] - Whether migrations are enabled for this database.\n * @property {string} [password] - Password for the database user.\n * @property {number} [port] - Database port.\n * @property {string} [name] - Friendly name for the configuration.\n * @property {(file: string) => string} [locateFile] - Optional sqlite-web sql.js wasm resolver (`initSqlJs({locateFile})`).\n * @property {boolean} [readOnly] - Whether writes should be blocked for this database.\n * @property {string} [schema] - Default schema for unqualified table lookups (MSSQL).\n * @property {object} [record] - Record-level configuration.\n * @property {boolean} [record.transactions] - Whether record operations should use transactions.\n * @property {boolean} [reset] - Whether to reset the database on startup.\n * @property {SqlConfig} [sqlConfig] - Driver-specific SQL config.\n * @property {\"mssql\" | \"mysql\" | \"pgsql\" | \"sqlite\"} [type] - Database type identifier.\n * @property {string} [useDatabase] - Database to switch to after connecting.\n * @property {string} [username] - Username for database authentication.\n */\n\n/**\n * @typedef {\"debug-low-level\" | \"debug\" | \"info\" | \"warn\" | \"error\"} LogLevel\n */\n\n/**\n * @typedef {object} LoggingOutputPayload\n * @property {LogLevel} level - Log level.\n * @property {string} message - Formatted message.\n * @property {string} subject - Log subject.\n * @property {Date} timestamp - Timestamp.\n */\n\n/**\n * @typedef {object} LoggingOutput\n * @property {function(LoggingOutputPayload): Promise<void> | void} write - Write a log entry.\n * @property {LogLevel[]} [levels] - Default levels for this output.\n */\n\n/**\n * @typedef {object} LoggingOutputConfig\n * @property {LoggingOutput} output - Output instance.\n * @property {Array<LogLevel>} [levels] - Levels enabled for this output.\n */\n\n/**\n * @typedef {LoggingOutputConfig | LoggingOutput | import(\"./logger/base-logger.js\").default} LoggerConfig\n */\n\n/**\n * @typedef {object} LoggingConfiguration\n * @property {boolean} [console] - Enable/disable console logging for request logging. Defaults to true outside of \"test\" and for HTTP server logs.\n * @property {boolean} [file] - Enable/disable writing logs to a file. Defaults to true.\n * @property {string} [directory] - Directory where log files are stored. Defaults to \"<project>/log\".\n * @property {string} [filePath] - Explicit path for the log file. Defaults to \"<directory>/<environment>.log\".\n * @property {Array<\"debug-low-level\" | \"debug\" | \"info\" | \"warn\" | \"error\">} [levels] - Override which log levels are emitted.\n * @property {boolean} [debugLowLevel] - Convenience flag to include very low-level debug logs.\n * @property {LoggerConfig[]} [loggers] - Logger instances (converted to outputs when configured).\n * @property {LoggingOutputConfig[]} [outputs] - Explicit logger outputs (overrides console/file defaults when provided).\n */\n\n/**\n * @typedef {object} StructureSqlConfiguration\n * @property {string[]} [disabledEnvironments] - Environments that should skip writing structure sql files.\n */\n\n/**\n * @typedef {object} BackgroundJobsConfiguration\n * @property {string} [host] - Hostname for the background jobs main process.\n * @property {number} [port] - Port for the background jobs main process.\n * @property {string} [databaseIdentifier] - Database identifier used to store background jobs.\n */\n\n/**\n * @typedef {object} ScheduledBackgroundJobEveryOptions\n * @property {number | string} [firstIn] - Delay before the first enqueue.\n * @property {number | string} [first_in] - Sidekiq-style alias for `firstIn`.\n */\n\n/**\n * @typedef {object} ScheduledBackgroundJobConfiguration\n * @property {any[]} [args] - Arguments passed to the job when enqueued.\n * @property {typeof import(\"./background-jobs/job.js\").default} class - Job class to enqueue.\n * @property {boolean} [enabled] - Whether the schedule is enabled.\n * @property {number | string | [number | string, ScheduledBackgroundJobEveryOptions]} every - Repeat interval.\n * @property {import(\"./background-jobs/types.js\").BackgroundJobOptions} [options] - Job options.\n */\n\n/**\n * @typedef {object} ScheduledBackgroundJobsConfiguration\n * @property {Record<string, ScheduledBackgroundJobConfiguration>} jobs - Scheduled jobs keyed by name.\n */\n\n/**\n * @typedef {function({configuration: import(\"./configuration.js\").default}) : ScheduledBackgroundJobsConfiguration | Promise<ScheduledBackgroundJobsConfiguration>} ScheduledBackgroundJobsLoaderType\n */\n\n/**\n * @typedef {object} AttachmentDriverConfiguration\n * @property {function({configuration: import(\"./configuration.js\").default, name: string, options: Record<string, any>}) : Record<string, any>} [create] - Optional factory for a custom attachment driver instance.\n * @property {new (...args: any[]) => Record<string, any>} [driverClass] - Optional custom attachment driver class.\n * @property {Record<string, any>} [instance] - Optional custom attachment driver instance.\n */\n\n/**\n * @typedef {object} AttachmentsConfiguration\n * @property {string} [defaultDriver] - Default attachment storage driver name.\n * @property {Record<string, AttachmentDriverConfiguration & Record<string, any>>} [drivers] - Named attachment driver configurations.\n * @property {boolean} [allowPathInput] - Whether `{path: ...}` attachment input is allowed.\n * @property {string[]} [allowedPathPrefixes] - Optional allowlist of directories for `{path: ...}` input.\n */\n\n/**\n * @typedef {object} MailerBackend\n * @property {function({payload: import(\"./mailer.js\").MailerDeliveryPayload, configuration: import(\"./configuration.js\").default}) : Promise<unknown> | unknown} deliver - Deliver a mailer payload.\n */\n\n\n/**\n * @typedef {Record<string, string[]>} LocaleFallbacksType\n */\n\n/**\n * @typedef {object} FrontendModelRelationshipConfiguration\n * @property {\"belongsTo\" | \"hasOne\" | \"hasMany\"} type - Relationship type.\n * @property {string} [model] - Target model class name.\n * @property {string} [className] - Alias of target model class name.\n * @property {string} [modelClassName] - Explicit target model class name.\n */\n\n/**\n * @typedef {object} FrontendModelAttributeConfiguration\n * @property {string} [type] - Column type name.\n * @property {string} [columnType] - Alias for column type name.\n * @property {string} [sqlType] - Alias for column type name.\n * @property {string} [dataType] - Alias for column type name.\n * @property {boolean} [null] - Whether value can be null.\n */\n\n/**\n * @typedef {object} FrontendModelAttachmentConfiguration\n * @property {\"hasOne\" | \"hasMany\"} type - Attachment cardinality.\n */\n\n/**\n * @typedef {object} FrontendModelResourceConfiguration\n * @property {string[] | Record<string, FrontendModelAttributeConfiguration | import(\"./database/drivers/base-column.js\").default | boolean>} attributes - Attributes to expose on the frontend model.\n * @property {FrontendModelResourceAbilitiesConfiguration | string[]} [abilities] - Ability actions keyed by frontend command (`index`, `find`, `create`, `update`, `destroy`) or shorthand action list. Defaults to `{find: \"read\", index: \"read\"}` when omitted.\n * @property {Record<string, FrontendModelAttachmentConfiguration>} [attachments] - Attachment helpers keyed by attachment name.\n * @property {Record<string, string> | string[]} [commands] - Legacy built-in command names keyed by action (`index`, `find`, `create`, `update`, `destroy`, `attach`, `download`, `url`) or shorthand command list using default names.\n * @property {Record<string, string> | string[]} [collectionCommands] - Custom collection commands keyed by generated method name or shorthand command list using camelized method names. When `builtInCollectionCommands` and `builtInMemberCommands` are omitted, this key keeps its legacy built-in-command behavior.\n * @property {Record<string, string> | string[]} [memberCommands] - Custom member commands keyed by generated method name or shorthand command list using camelized method names. When `builtInCollectionCommands` and `builtInMemberCommands` are omitted, this key keeps its legacy built-in-command behavior.\n * @property {Record<string, string> | string[]} [builtInCollectionCommands] - Built-in collection command names keyed by action (`index`, `create`) or shorthand command list using default names.\n * @property {Record<string, string> | string[]} [builtInMemberCommands] - Built-in member command names keyed by action (`find`, `update`, `destroy`, `attach`, `download`, `url`) or shorthand command list using default names.\n * @property {string[]} [relationships] - Relationship names to expose in frontend models. Type and target model are inferred from the backend model's registered relationships.\n * @property {string} [path] - Resource path (e.g., \"/users\"). Generated into frontend model resourceConfig so minified class names don't break path derivation.\n * @property {string} [primaryKey] - Primary key attribute name.\n * @property {FrontendModelResourceServerConfiguration} [server] - Optional legacy backend behavior overrides for built-in frontend actions.\n */\n\n/**\n * @typedef {Omit<FrontendModelResourceConfiguration, \"abilities\" | \"builtInCollectionCommands\" | \"builtInMemberCommands\" | \"collectionCommands\" | \"commands\" | \"memberCommands\"> & {\n *   abilities: FrontendModelResourceAbilitiesConfiguration\n *   builtInCollectionCommands: Record<string, string>\n *   builtInMemberCommands: Record<string, string>\n *   collectionCommands: Record<string, string>\n *   memberCommands: Record<string, string>\n * }} NormalizedFrontendModelResourceConfiguration\n */\n\n/**\n * @typedef {typeof import(\"./frontend-model-resource/base-resource.js\").default} FrontendModelResourceClassType\n */\n\n/**\n * @typedef {FrontendModelResourceClassType} FrontendModelResourceDefinition\n */\n\n/**\n * @typedef {object} FrontendModelResourceAbilitiesConfiguration\n * @property {string} [index] - Ability action for frontend index.\n * @property {string} [find] - Ability action for frontend find.\n * @property {string} [create] - Ability action for frontend create.\n * @property {string} [update] - Ability action for frontend update.\n * @property {string} [destroy] - Ability action for frontend destroy.\n */\n\n/**\n * @typedef {object} FrontendModelResourceServerConfiguration\n * @property {function({action: \"index\" | \"find\" | \"create\" | \"update\" | \"destroy\" | \"attach\" | \"download\" | \"url\", controller: import(\"./controller.js\").default, params: Record<string, any>, modelClass: typeof import(\"./database/record/index.js\").default}) : (boolean | void | Promise<boolean | void>)} [beforeAction] - Optional callback run before built-in frontend actions.\n * @property {function({action: \"index\", controller: import(\"./controller.js\").default, params: Record<string, any>, modelClass: typeof import(\"./database/record/index.js\").default}) : Promise<import(\"./database/record/index.js\").default[]>} [records] - Records loader for frontendIndex.\n * @property {function({action: \"index\" | \"find\" | \"create\" | \"update\", controller: import(\"./controller.js\").default, params: Record<string, any>, modelClass: typeof import(\"./database/record/index.js\").default, model: import(\"./database/record/index.js\").default}) : Record<string, any> | Promise<Record<string, any>>} [serialize] - Record serializer for response payloads.\n * @property {function({action: \"find\" | \"update\" | \"destroy\" | \"attach\" | \"download\" | \"url\", controller: import(\"./controller.js\").default, params: Record<string, any>, modelClass: typeof import(\"./database/record/index.js\").default, id: string | number}) : Promise<import(\"./database/record/index.js\").default | null>} [find] - Record loader for find/update/destroy/attach/download/url actions.\n * @property {function({action: \"create\", controller: import(\"./controller.js\").default, params: Record<string, any>, modelClass: typeof import(\"./database/record/index.js\").default, attributes: Record<string, any>}) : Promise<import(\"./database/record/index.js\").default>} [create] - Custom create callback.\n * @property {function({action: \"update\", controller: import(\"./controller.js\").default, params: Record<string, any>, modelClass: typeof import(\"./database/record/index.js\").default, model: import(\"./database/record/index.js\").default, attributes: Record<string, any>}) : Promise<import(\"./database/record/index.js\").default | void>} [update] - Custom update callback.\n * @property {function({action: \"destroy\", controller: import(\"./controller.js\").default, params: Record<string, any>, modelClass: typeof import(\"./database/record/index.js\").default, model: import(\"./database/record/index.js\").default}) : Promise<void>} [destroy] - Custom destroy callback.\n */\n\n/**\n * @typedef {object} BackendProjectConfiguration\n * @property {string} path - Path to the backend project.\n * @property {string} [frontendModelsOutputPath] - Optional output project path where `src/frontend-models` should be generated.\n * @property {Record<string, FrontendModelResourceDefinition>} [frontendModels] - Frontend model definitions keyed by model class name.\n * @property {{(id: string): {default?: unknown}, keys: () => string[]}} [frontendModelsRequireContext] - Webpack-style require context for frontend model resource files.\n * @property {Record<string, FrontendModelResourceDefinition>} [resources] - Alias for `frontendModels`.\n * @property {{(id: string): {default?: unknown}, keys: () => string[]}} [resourcesRequireContext] - Alias for `frontendModelsRequireContext`.\n */\n\n/**\n * @typedef {object} RouteResolverHookArgs\n * @property {import(\"./configuration.js\").default} configuration - Configuration instance.\n * @property {Record<string, any>} params - Mutable request params object.\n * @property {string} currentPath - Request path without query.\n * @property {boolean} [hasMatchingCustomRoute] - True when matching a configured custom route.\n * @property {import(\"./http-server/client/request.js\").default | import(\"./http-server/client/websocket-request.js\").default} request - Request object.\n * @property {import(\"./http-server/client/response.js\").default} response - Response object.\n * @property {import(\"./routes/resolver.js\").default} resolver - Resolver instance.\n */\n\n/**\n * @typedef {object} RouteResolverHookResult\n * @property {string} action - Dasherized action name (for example `frontend-index`).\n * @property {string} controller - Controller path (for example `accounts`).\n * @property {typeof import(\"./controller.js\").default} [controllerClass] - Optional controller class override.\n * @property {string} [controllerPath] - Optional absolute/relative controller file path override.\n * @property {Record<string, any>} [params] - Extra params to merge for controller/action.\n * @property {string} [viewPath] - Optional view path override used by controller render lookups.\n */\n\n/**\n * @typedef {function(RouteResolverHookArgs) : RouteResolverHookResult | null | Promise<RouteResolverHookResult | null>} RouteResolverHookType\n */\n\n/**\n * @typedef {typeof import(\"./authorization/base-resource.js\").default} AbilityResourceClassType\n */\n\n/**\n * @typedef {function({configuration: import(\"./configuration.js\").default, params: Record<string, any>, request: import(\"./http-server/client/request.js\").default | import(\"./http-server/client/websocket-request.js\").default, response: import(\"./http-server/client/response.js\").default}) : import(\"./authorization/ability.js\").default | void | Promise<import(\"./authorization/ability.js\").default | void>} AbilityResolverType\n */\n\n/**\n * @typedef {function({configuration: import(\"./configuration.js\").default, params: Record<string, any>, request: import(\"./http-server/client/request.js\").default | import(\"./http-server/client/websocket-request.js\").default | undefined, response: import(\"./http-server/client/response.js\").default | undefined, subscription?: {channel: string, params?: Record<string, unknown>}}) : unknown | void | Promise<unknown | void>} TenantResolverType\n */\n\n/**\n * @typedef {function({configuration: import(\"./configuration.js\").default, databaseConfiguration: DatabaseConfigurationType, identifier: string, tenant: unknown}) : DatabaseConfigurationType | Partial<DatabaseConfigurationType> | void} TenantDatabaseResolverType\n */\n\n/**\n * @typedef {object} ConfigurationArgsType\n * @property {CorsType} [cors] - CORS configuration for the HTTP server.\n * @property {string} [cookieSecret] - Secret for encrypting cookies.\n * @property {AbilityResourceClassType[]} [abilityResources] - Resource classes used to define abilities per model.\n * @property {AbilityResolverType} [abilityResolver] - Resolver for creating request-scoped ability instances.\n * @property {AttachmentsConfiguration} [attachments] - Attachment storage configuration.\n * @property {BackendProjectConfiguration[]} [backendProjects] - Backend project definitions used for frontend model generation.\n * @property {{[key: string]: {[key: string]: DatabaseConfigurationType}}} database - Database configurations keyed by environment and identifier.\n * @property {boolean} [debug] - Enable debug logging.\n * @property {string} [directory] - Base directory for the project.\n * @property {string} [environment] - Current environment name.\n * @property {import(\"./environment-handlers/base.js\").default} environmentHandler - Environment handler instance.\n * @property {LoggingConfiguration} [logging] - Logging configuration.\n * @property {BackgroundJobsConfiguration} [backgroundJobs] - Background jobs configuration.\n * @property {ScheduledBackgroundJobsConfiguration | ScheduledBackgroundJobsLoaderType} [scheduledBackgroundJobs] - Scheduled background jobs configuration.\n * @property {MailerBackend} [mailerBackend] - Mail delivery backend.\n * @property {function({configuration: import(\"./configuration.js\").default, type: string}) : void} initializeModels - Hook to register models for a given initialization type.\n * @property {InitializersType} [initializers] - Initializer loader for environment bootstrapping.\n * @property {string | function() : string} locale - Default locale or locale resolver.\n * @property {string[]} locales - Supported locales.\n * @property {LocaleFallbacksType} localeFallbacks - Locale fallback map.\n * @property {StructureSqlConfiguration} [structureSql] - Structure SQL generation configuration.\n * @property {TenantResolverType} [tenantResolver] - Resolver for creating request-scoped tenant context objects.\n * @property {TenantDatabaseResolverType} [tenantDatabaseResolver] - Resolver for deriving tenant-specific database config overrides.\n * @property {string} [testing] - Path to the testing configuration file.\n * @property {number | (() => number)} [timezoneOffsetMinutes] - Default timezone offset in minutes.\n * @property {number | (() => number)} [requestTimeoutMs] - Timeout in seconds for completing a HTTP request.\n * @property {RouteResolverHookType[]} [routeResolverHooks] - Hook callbacks that can hijack unresolved routes.\n * @property {WebsocketChannelResolverType} [websocketChannelResolver] - Resolve a websocket channel class/instance for each connection.\n * @property {WebsocketMessageHandlerResolverType} [websocketMessageHandlerResolver] - Resolve a raw websocket message handler for each connection.\n */\n\nexport const nothing = {}\n"]}
|
|
292
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"configuration-types.js","sourceRoot":"","sources":["../../src/configuration-types.js"],"names":[],"mappings":"AAAA,YAAY;AAEZ;;GAEG;AAEH;;GAEG;AAEH;;GAEG;AAEH;;;;;;GAMG;AAEH;;GAEG;AAEH;;;;;;;;GAQG;AAEH;;;;;;;;;;;;;;;GAeG;AAEH;;;;;;;;;;;;;;;;;;;;;GAqBG;AAEH;;GAEG;AAEH;;;;;;GAMG;AAEH;;;;GAIG;AAEH;;;;GAIG;AAEH;;GAEG;AAEH;;;;;;;;;;GAUG;AAEH;;;GAGG;AAEH;;;;;GAKG;AAEH;;;;GAIG;AAEH;;;;;;;GAOG;AAEH;;;GAGG;AAEH;;GAEG;AAEH;;;;;GAKG;AAEH;;;;;;GAMG;AAEH;;;GAGG;AAGH;;GAEG;AAEH;;;;;;GAMG;AAEH;;;;;;;GAOG;AAEH;;;GAGG;AAEH;;;;;;;;;;;;;;GAcG;AAEH;;;;;;;;GAQG;AAEH;;GAEG;AAEH;;GAEG;AAEH;;;;;;;GAOG;AAEH;;;;;;;;;GASG;AAEH;;;;;GAKG;AAEH;;;;;;;;;GASG;AAEH;;;;;;;;GAQG;AAEH;;GAEG;AAEH;;GAEG;AAEH;;GAEG;AAEH;;GAEG;AAEH;;GAEG;AAEH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+BG;AAEH,MAAM,CAAC,MAAM,OAAO,GAAG,EAAE,CAAA","sourcesContent":["// @ts-check\n\n/**\n * @module types\n */\n\n/**\n * @typedef {function({request: import(\"./http-server/client/request.js\").default | import(\"./http-server/client/websocket-request.js\").default, response: import(\"./http-server/client/response.js\").default}): Promise<void>} CorsType\n */\n\n/**\n * @typedef {function({request: import(\"./http-server/client/request.js\").default | import(\"./http-server/client/websocket-request.js\").default | undefined, subscription?: {channel: string, params?: Record<string, unknown>}, client: import(\"./http-server/client/index.js\").default, websocketSession: import(\"./http-server/client/websocket-session.js\").default, configuration: import(\"./configuration.js\").default}): typeof import(\"./http-server/websocket-channel.js\").default | import(\"./http-server/websocket-channel.js\").default | void | Promise<typeof import(\"./http-server/websocket-channel.js\").default | import(\"./http-server/websocket-channel.js\").default | void>} WebsocketChannelResolverType\n */\n\n/**\n * @typedef {object} WebsocketMessageHandler\n * @property {function({message: any, session: import(\"./http-server/client/websocket-session.js\").default}) : Promise<void> | void} [onMessage] - Handler for incoming websocket messages.\n * @property {function({session: import(\"./http-server/client/websocket-session.js\").default}) : Promise<void> | void} [onOpen] - Handler when the websocket session opens.\n * @property {function({session: import(\"./http-server/client/websocket-session.js\").default}) : Promise<void> | void} [onClose] - Handler when the websocket session closes.\n * @property {function({error: Error, session: import(\"./http-server/client/websocket-session.js\").default}) : Promise<void> | void} [onError] - Handler when a websocket message errors.\n */\n\n/**\n * @typedef {function({request: import(\"./http-server/client/request.js\").default | import(\"./http-server/client/websocket-request.js\").default | undefined, client: import(\"./http-server/client/index.js\").default, configuration: import(\"./configuration.js\").default}): WebsocketMessageHandler | void | Promise<WebsocketMessageHandler | void>} WebsocketMessageHandlerResolverType\n */\n\n/**\n * @typedef {(id: string) => {default: typeof import(\"./initializer.js\").default}} InitializersRequireContextType\n * @typedef {InitializersRequireContextType & {\n *   keys: () => string[],\n *   id: string\n * }} WebpackRequireContext\n * @typedef {{requireContext: WebpackRequireContext}} InitializersExportType\n * @typedef {function({configuration: import(\"./configuration.js\").default}) : Promise<InitializersExportType>} InitializersType\n */\n\n/**\n * @typedef {object} SqlConfig\n * @property {string} [database] - Database name for the SQL driver.\n * @property {object} [options] - Driver-specific connection options.\n * @property {boolean} [options.encrypt] - Whether to encrypt the connection (MSSQL).\n * @property {string} [options.schema] - Default schema for unqualified table lookups (MSSQL).\n * @property {string} [options.serverName] - TLS SNI server name override for MSSQL (empty string disables SNI).\n * @property {boolean} [options.trustServerCertificate] - Whether to trust the server certificate (MSSQL).\n * @property {string} [password] - Password for the SQL user.\n * @property {object} [pool] - Connection pool configuration.\n * @property {number} [pool.max] - Maximum number of connections.\n * @property {number} [pool.min] - Minimum number of connections.\n * @property {number} [pool.idleTimeoutMillis] - Idle timeout before releasing a connection.\n * @property {string} [server] - SQL server hostname.\n * @property {string} [user] - SQL username.\n */\n\n/**\n * @typedef {object} DatabaseConfigurationType\n * @property {string} [database] - Database name for this connection.\n * @property {typeof import(\"./database/drivers/base.js\").default} [driver] - Driver class to use for this database.\n * @property {typeof import(\"./database/pool/base.js\").default} [poolType] - Pool class to use for this database.\n * @property {function() : unknown} [getConnection] - Custom connection factory override.\n * @property {string} [host] - Database host.\n * @property {boolean} [migrations] - Whether migrations are enabled for this database.\n * @property {string} [password] - Password for the database user.\n * @property {number} [port] - Database port.\n * @property {string} [name] - Friendly name for the configuration.\n * @property {(file: string) => string} [locateFile] - Optional sqlite-web sql.js wasm resolver (`initSqlJs({locateFile})`).\n * @property {boolean} [readOnly] - Whether writes should be blocked for this database.\n * @property {string} [schema] - Default schema for unqualified table lookups (MSSQL).\n * @property {object} [record] - Record-level configuration.\n * @property {boolean} [record.transactions] - Whether record operations should use transactions.\n * @property {boolean} [reset] - Whether to reset the database on startup.\n * @property {SqlConfig} [sqlConfig] - Driver-specific SQL config.\n * @property {\"mssql\" | \"mysql\" | \"pgsql\" | \"sqlite\"} [type] - Database type identifier.\n * @property {string} [useDatabase] - Database to switch to after connecting.\n * @property {string} [username] - Username for database authentication.\n */\n\n/**\n * @typedef {\"debug-low-level\" | \"debug\" | \"info\" | \"warn\" | \"error\"} LogLevel\n */\n\n/**\n * @typedef {object} LoggingOutputPayload\n * @property {LogLevel} level - Log level.\n * @property {string} message - Formatted message.\n * @property {string} subject - Log subject.\n * @property {Date} timestamp - Timestamp.\n */\n\n/**\n * @typedef {object} LoggingOutput\n * @property {function(LoggingOutputPayload): Promise<void> | void} write - Write a log entry.\n * @property {LogLevel[]} [levels] - Default levels for this output.\n */\n\n/**\n * @typedef {object} LoggingOutputConfig\n * @property {LoggingOutput} output - Output instance.\n * @property {Array<LogLevel>} [levels] - Levels enabled for this output.\n */\n\n/**\n * @typedef {LoggingOutputConfig | LoggingOutput | import(\"./logger/base-logger.js\").default} LoggerConfig\n */\n\n/**\n * @typedef {object} LoggingConfiguration\n * @property {boolean} [console] - Enable/disable console logging for request logging. Defaults to true outside of \"test\" and for HTTP server logs.\n * @property {boolean} [file] - Enable/disable writing logs to a file. Defaults to true.\n * @property {string} [directory] - Directory where log files are stored. Defaults to \"<project>/log\".\n * @property {string} [filePath] - Explicit path for the log file. Defaults to \"<directory>/<environment>.log\".\n * @property {Array<\"debug-low-level\" | \"debug\" | \"info\" | \"warn\" | \"error\">} [levels] - Override which log levels are emitted.\n * @property {boolean} [debugLowLevel] - Convenience flag to include very low-level debug logs.\n * @property {LoggerConfig[]} [loggers] - Logger instances (converted to outputs when configured).\n * @property {LoggingOutputConfig[]} [outputs] - Explicit logger outputs (overrides console/file defaults when provided).\n */\n\n/**\n * @typedef {object} StructureSqlConfiguration\n * @property {string[]} [disabledEnvironments] - Environments that should skip writing structure sql files.\n */\n\n/**\n * @typedef {object} BackgroundJobsConfiguration\n * @property {string} [host] - Hostname for the background jobs main process.\n * @property {number} [port] - Port for the background jobs main process.\n * @property {string} [databaseIdentifier] - Database identifier used to store background jobs.\n */\n\n/**\n * @typedef {object} ScheduledBackgroundJobEveryOptions\n * @property {number | string} [firstIn] - Delay before the first enqueue.\n * @property {number | string} [first_in] - Sidekiq-style alias for `firstIn`.\n */\n\n/**\n * @typedef {object} ScheduledBackgroundJobConfiguration\n * @property {any[]} [args] - Arguments passed to the job when enqueued.\n * @property {typeof import(\"./background-jobs/job.js\").default} class - Job class to enqueue.\n * @property {boolean} [enabled] - Whether the schedule is enabled.\n * @property {number | string | [number | string, ScheduledBackgroundJobEveryOptions]} every - Repeat interval.\n * @property {import(\"./background-jobs/types.js\").BackgroundJobOptions} [options] - Job options.\n */\n\n/**\n * @typedef {object} ScheduledBackgroundJobsConfiguration\n * @property {Record<string, ScheduledBackgroundJobConfiguration>} jobs - Scheduled jobs keyed by name.\n */\n\n/**\n * @typedef {function({configuration: import(\"./configuration.js\").default}) : ScheduledBackgroundJobsConfiguration | Promise<ScheduledBackgroundJobsConfiguration>} ScheduledBackgroundJobsLoaderType\n */\n\n/**\n * @typedef {object} AttachmentDriverConfiguration\n * @property {function({configuration: import(\"./configuration.js\").default, name: string, options: Record<string, any>}) : Record<string, any>} [create] - Optional factory for a custom attachment driver instance.\n * @property {new (...args: any[]) => Record<string, any>} [driverClass] - Optional custom attachment driver class.\n * @property {Record<string, any>} [instance] - Optional custom attachment driver instance.\n */\n\n/**\n * @typedef {object} AttachmentsConfiguration\n * @property {string} [defaultDriver] - Default attachment storage driver name.\n * @property {Record<string, AttachmentDriverConfiguration & Record<string, any>>} [drivers] - Named attachment driver configurations.\n * @property {boolean} [allowPathInput] - Whether `{path: ...}` attachment input is allowed.\n * @property {string[]} [allowedPathPrefixes] - Optional allowlist of directories for `{path: ...}` input.\n */\n\n/**\n * @typedef {object} MailerBackend\n * @property {function({payload: import(\"./mailer.js\").MailerDeliveryPayload, configuration: import(\"./configuration.js\").default}) : Promise<unknown> | unknown} deliver - Deliver a mailer payload.\n */\n\n\n/**\n * @typedef {Record<string, string[]>} LocaleFallbacksType\n */\n\n/**\n * @typedef {object} FrontendModelRelationshipConfiguration\n * @property {\"belongsTo\" | \"hasOne\" | \"hasMany\"} type - Relationship type.\n * @property {string} [model] - Target model class name.\n * @property {string} [className] - Alias of target model class name.\n * @property {string} [modelClassName] - Explicit target model class name.\n */\n\n/**\n * @typedef {object} FrontendModelAttributeConfiguration\n * @property {string} [type] - Column type name.\n * @property {string} [columnType] - Alias for column type name.\n * @property {string} [sqlType] - Alias for column type name.\n * @property {string} [dataType] - Alias for column type name.\n * @property {boolean} [null] - Whether value can be null.\n */\n\n/**\n * @typedef {object} FrontendModelAttachmentConfiguration\n * @property {\"hasOne\" | \"hasMany\"} type - Attachment cardinality.\n */\n\n/**\n * @typedef {object} FrontendModelResourceConfiguration\n * @property {string[] | Record<string, FrontendModelAttributeConfiguration | import(\"./database/drivers/base-column.js\").default | boolean>} attributes - Attributes to expose on the frontend model.\n * @property {FrontendModelResourceAbilitiesConfiguration | string[]} [abilities] - Ability actions keyed by frontend command (`index`, `find`, `create`, `update`, `destroy`) or shorthand action list. Defaults to `{find: \"read\", index: \"read\"}` when omitted.\n * @property {Record<string, FrontendModelAttachmentConfiguration>} [attachments] - Attachment helpers keyed by attachment name.\n * @property {Record<string, string> | string[]} [commands] - Legacy built-in command names keyed by action (`index`, `find`, `create`, `update`, `destroy`, `attach`, `download`, `url`) or shorthand command list using default names.\n * @property {Record<string, string> | string[]} [collectionCommands] - Custom collection commands keyed by generated method name or shorthand command list using camelized method names. When `builtInCollectionCommands` and `builtInMemberCommands` are omitted, this key keeps its legacy built-in-command behavior.\n * @property {Record<string, string> | string[]} [memberCommands] - Custom member commands keyed by generated method name or shorthand command list using camelized method names. When `builtInCollectionCommands` and `builtInMemberCommands` are omitted, this key keeps its legacy built-in-command behavior.\n * @property {Record<string, string> | string[]} [builtInCollectionCommands] - Built-in collection command names keyed by action (`index`, `create`) or shorthand command list using default names.\n * @property {Record<string, string> | string[]} [builtInMemberCommands] - Built-in member command names keyed by action (`find`, `update`, `destroy`, `attach`, `download`, `url`) or shorthand command list using default names.\n * @property {string[]} [relationships] - Relationship names to expose in frontend models. Type and target model are inferred from the backend model's registered relationships.\n * @property {string} [path] - Resource path (e.g., \"/users\"). Generated into frontend model resourceConfig so minified class names don't break path derivation.\n * @property {string} [primaryKey] - Primary key attribute name.\n * @property {FrontendModelResourceServerConfiguration} [server] - Optional legacy backend behavior overrides for built-in frontend actions.\n */\n\n/**\n * @typedef {Omit<FrontendModelResourceConfiguration, \"abilities\" | \"builtInCollectionCommands\" | \"builtInMemberCommands\" | \"collectionCommands\" | \"commands\" | \"memberCommands\"> & {\n *   abilities: FrontendModelResourceAbilitiesConfiguration\n *   builtInCollectionCommands: Record<string, string>\n *   builtInMemberCommands: Record<string, string>\n *   collectionCommands: Record<string, string>\n *   memberCommands: Record<string, string>\n * }} NormalizedFrontendModelResourceConfiguration\n */\n\n/**\n * @typedef {typeof import(\"./frontend-model-resource/base-resource.js\").default} FrontendModelResourceClassType\n */\n\n/**\n * @typedef {FrontendModelResourceClassType} FrontendModelResourceDefinition\n */\n\n/**\n * @typedef {object} FrontendModelResourceAbilitiesConfiguration\n * @property {string} [index] - Ability action for frontend index.\n * @property {string} [find] - Ability action for frontend find.\n * @property {string} [create] - Ability action for frontend create.\n * @property {string} [update] - Ability action for frontend update.\n * @property {string} [destroy] - Ability action for frontend destroy.\n */\n\n/**\n * @typedef {object} FrontendModelResourceServerConfiguration\n * @property {function({action: \"index\" | \"find\" | \"create\" | \"update\" | \"destroy\" | \"attach\" | \"download\" | \"url\", controller: import(\"./controller.js\").default, params: Record<string, any>, modelClass: typeof import(\"./database/record/index.js\").default}) : (boolean | void | Promise<boolean | void>)} [beforeAction] - Optional callback run before built-in frontend actions.\n * @property {function({action: \"index\", controller: import(\"./controller.js\").default, params: Record<string, any>, modelClass: typeof import(\"./database/record/index.js\").default}) : Promise<import(\"./database/record/index.js\").default[]>} [records] - Records loader for frontendIndex.\n * @property {function({action: \"index\" | \"find\" | \"create\" | \"update\", controller: import(\"./controller.js\").default, params: Record<string, any>, modelClass: typeof import(\"./database/record/index.js\").default, model: import(\"./database/record/index.js\").default}) : Record<string, any> | Promise<Record<string, any>>} [serialize] - Record serializer for response payloads.\n * @property {function({action: \"find\" | \"update\" | \"destroy\" | \"attach\" | \"download\" | \"url\", controller: import(\"./controller.js\").default, params: Record<string, any>, modelClass: typeof import(\"./database/record/index.js\").default, id: string | number}) : Promise<import(\"./database/record/index.js\").default | null>} [find] - Record loader for find/update/destroy/attach/download/url actions.\n * @property {function({action: \"create\", controller: import(\"./controller.js\").default, params: Record<string, any>, modelClass: typeof import(\"./database/record/index.js\").default, attributes: Record<string, any>}) : Promise<import(\"./database/record/index.js\").default>} [create] - Custom create callback.\n * @property {function({action: \"update\", controller: import(\"./controller.js\").default, params: Record<string, any>, modelClass: typeof import(\"./database/record/index.js\").default, model: import(\"./database/record/index.js\").default, attributes: Record<string, any>}) : Promise<import(\"./database/record/index.js\").default | void>} [update] - Custom update callback.\n * @property {function({action: \"destroy\", controller: import(\"./controller.js\").default, params: Record<string, any>, modelClass: typeof import(\"./database/record/index.js\").default, model: import(\"./database/record/index.js\").default}) : Promise<void>} [destroy] - Custom destroy callback.\n */\n\n/**\n * @typedef {object} BackendProjectConfiguration\n * @property {string} path - Path to the backend project.\n * @property {string} [frontendModelsOutputPath] - Optional output project path where `src/frontend-models` should be generated.\n * @property {Record<string, FrontendModelResourceDefinition>} [frontendModels] - Auto-discovered frontend model definitions keyed by model class name. Set internally by the environment handler — do not set manually.\n */\n\n/**\n * @typedef {object} RouteResolverHookArgs\n * @property {import(\"./configuration.js\").default} configuration - Configuration instance.\n * @property {Record<string, any>} params - Mutable request params object.\n * @property {string} currentPath - Request path without query.\n * @property {boolean} [hasMatchingCustomRoute] - True when matching a configured custom route.\n * @property {import(\"./http-server/client/request.js\").default | import(\"./http-server/client/websocket-request.js\").default} request - Request object.\n * @property {import(\"./http-server/client/response.js\").default} response - Response object.\n * @property {import(\"./routes/resolver.js\").default} resolver - Resolver instance.\n */\n\n/**\n * @typedef {object} RouteResolverHookResult\n * @property {string} action - Dasherized action name (for example `frontend-index`).\n * @property {string} controller - Controller path (for example `accounts`).\n * @property {typeof import(\"./controller.js\").default} [controllerClass] - Optional controller class override.\n * @property {string} [controllerPath] - Optional absolute/relative controller file path override.\n * @property {Record<string, any>} [params] - Extra params to merge for controller/action.\n * @property {string} [viewPath] - Optional view path override used by controller render lookups.\n */\n\n/**\n * @typedef {function(RouteResolverHookArgs) : RouteResolverHookResult | null | Promise<RouteResolverHookResult | null>} RouteResolverHookType\n */\n\n/**\n * @typedef {typeof import(\"./authorization/base-resource.js\").default} AbilityResourceClassType\n */\n\n/**\n * @typedef {function({configuration: import(\"./configuration.js\").default, params: Record<string, any>, request: import(\"./http-server/client/request.js\").default | import(\"./http-server/client/websocket-request.js\").default, response: import(\"./http-server/client/response.js\").default}) : import(\"./authorization/ability.js\").default | void | Promise<import(\"./authorization/ability.js\").default | void>} AbilityResolverType\n */\n\n/**\n * @typedef {function({configuration: import(\"./configuration.js\").default, params: Record<string, any>, request: import(\"./http-server/client/request.js\").default | import(\"./http-server/client/websocket-request.js\").default | undefined, response: import(\"./http-server/client/response.js\").default | undefined, subscription?: {channel: string, params?: Record<string, unknown>}}) : unknown | void | Promise<unknown | void>} TenantResolverType\n */\n\n/**\n * @typedef {function({configuration: import(\"./configuration.js\").default, databaseConfiguration: DatabaseConfigurationType, identifier: string, tenant: unknown}) : DatabaseConfigurationType | Partial<DatabaseConfigurationType> | void} TenantDatabaseResolverType\n */\n\n/**\n * @typedef {object} ConfigurationArgsType\n * @property {CorsType} [cors] - CORS configuration for the HTTP server.\n * @property {string} [cookieSecret] - Secret for encrypting cookies.\n * @property {AbilityResourceClassType[]} [abilityResources] - Resource classes used to define abilities per model.\n * @property {AbilityResolverType} [abilityResolver] - Resolver for creating request-scoped ability instances.\n * @property {AttachmentsConfiguration} [attachments] - Attachment storage configuration.\n * @property {BackendProjectConfiguration[]} [backendProjects] - Backend project definitions used for frontend model generation.\n * @property {{[key: string]: {[key: string]: DatabaseConfigurationType}}} database - Database configurations keyed by environment and identifier.\n * @property {boolean} [debug] - Enable debug logging.\n * @property {string} [directory] - Base directory for the project.\n * @property {string} [environment] - Current environment name.\n * @property {import(\"./environment-handlers/base.js\").default} environmentHandler - Environment handler instance.\n * @property {LoggingConfiguration} [logging] - Logging configuration.\n * @property {BackgroundJobsConfiguration} [backgroundJobs] - Background jobs configuration.\n * @property {ScheduledBackgroundJobsConfiguration | ScheduledBackgroundJobsLoaderType} [scheduledBackgroundJobs] - Scheduled background jobs configuration.\n * @property {MailerBackend} [mailerBackend] - Mail delivery backend.\n * @property {function({configuration: import(\"./configuration.js\").default, type: string}) : void} initializeModels - Hook to register models for a given initialization type.\n * @property {InitializersType} [initializers] - Initializer loader for environment bootstrapping.\n * @property {string | function() : string} locale - Default locale or locale resolver.\n * @property {string[]} locales - Supported locales.\n * @property {LocaleFallbacksType} localeFallbacks - Locale fallback map.\n * @property {StructureSqlConfiguration} [structureSql] - Structure SQL generation configuration.\n * @property {TenantResolverType} [tenantResolver] - Resolver for creating request-scoped tenant context objects.\n * @property {TenantDatabaseResolverType} [tenantDatabaseResolver] - Resolver for deriving tenant-specific database config overrides.\n * @property {string} [testing] - Path to the testing configuration file.\n * @property {number | (() => number)} [timezoneOffsetMinutes] - Default timezone offset in minutes.\n * @property {number | (() => number)} [requestTimeoutMs] - Timeout in seconds for completing a HTTP request.\n * @property {RouteResolverHookType[]} [routeResolverHooks] - Hook callbacks that can hijack unresolved routes.\n * @property {WebsocketChannelResolverType} [websocketChannelResolver] - Resolve a websocket channel class/instance for each connection.\n * @property {WebsocketMessageHandlerResolverType} [websocketMessageHandlerResolver] - Resolve a raw websocket message handler for each connection.\n */\n\nexport const nothing = {}\n"]}
|
|
@@ -6,6 +6,7 @@
|
|
|
6
6
|
* @property {boolean|object} [foreignKey] - Foreign key options or flag.
|
|
7
7
|
* @property {boolean|IndexArgType} [index] - Whether the column should be indexed.
|
|
8
8
|
* @property {boolean} [isNewColumn] - Whether this column is being added in a migration.
|
|
9
|
+
* @property {number} [limit] - Alias for maxLength (varchar length limit).
|
|
9
10
|
* @property {number} [maxLength] - Maximum length for the column value.
|
|
10
11
|
* @property {string} [notes] - Column notes or comment.
|
|
11
12
|
* @property {boolean} [null] - Whether the column allows null values.
|
|
@@ -191,6 +192,10 @@ export type TableColumnArgsType = {
|
|
|
191
192
|
* - Whether this column is being added in a migration.
|
|
192
193
|
*/
|
|
193
194
|
isNewColumn?: boolean | undefined;
|
|
195
|
+
/**
|
|
196
|
+
* - Alias for maxLength (varchar length limit).
|
|
197
|
+
*/
|
|
198
|
+
limit?: number | undefined;
|
|
194
199
|
/**
|
|
195
200
|
* - Maximum length for the column value.
|
|
196
201
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"table-column.d.ts","sourceRoot":"","sources":["../../../../src/database/table-data/table-column.js"],"names":[],"mappings":"AAUA
|
|
1
|
+
{"version":3,"file":"table-column.d.ts","sourceRoot":"","sources":["../../../../src/database/table-data/table-column.js"],"names":[],"mappings":"AAUA;;;;;;;;;;;;;;;;;GAiBG;AAEH;IACE;;;OAGG;IACH,kBAHW,MAAM,SACN,mBAAmB,EAwB7B;IAFC,0BAAsB;IACtB,aAAgB;IAGlB;;OAEG;IACH,WAFa,MAAM,CAEW;IAE9B;;OAEG;IACH,cAFa,MAAM,GAAG,SAAS,CAEM;IAErC;;;OAGG;IACH,oBAHW,MAAM,GACJ,IAAI,CAE8B;IAAzB,6BAAuB;IAE7C;;OAEG;IACH,iBAFa,MAAM,CAE2C;IAE9D;;OAEG;IACH,oBAFa,OAAO,CAE2C;IAE/D;;;OAGG;IACH,mCAHW,OAAO,GACL,IAAI,CAEgE;IAEjF;;OAEG;IACH,cAFa,OAAO,GAAG,CAAC,MAAM,OAAO,CAAC,CAEI;IAE1C;;;OAGG;IACH,uBAHW,GAAG,GACD,IAAI,CAEwC;IAEzD;;OAEG;IACH,iBAFa,OAAO,CAEqC;IAEzD;;OAEG;IACH,iBAFa,OAAO,GAAG,MAAM,GAAG,SAAS,CAEO;IAEhD;;;OAGG;IACH,6BAHW,OAAO,GAAG,MAAM,GAAG,SAAS,GAC1B,IAAI,CAEoD;IAErE;;OAEG;IACH,YAFa,OAAO,GAAC,YAAY,CAEc;IAE/C;;OAEG;IACH,gBAFa,YAAY,CAQxB;IAED,0BAMC;IAED;;;OAGG;IACH,mBAHW,OAAO,GAAC,YAAY,GAClB,IAAI,CAEgC;IAEjD;;OAEG;IACH,gBAFa,MAAM,GAAG,SAAS,CAEe;IAE9C;;;OAGG;IACH,2BAHW,MAAM,GAAG,SAAS,GAChB,IAAI,CAEgD;IAEjE;;OAEG;IACH,YAFa,MAAM,GAAG,SAAS,CAEO;IAEtC;;;OAGG;IACH,mBAHW,MAAM,GAAG,SAAS,GAChB,IAAI,CAEgC;IAEjD;;OAEG;IACH,WAFa,OAAO,GAAG,SAAS,CAEI;IAEpC;;;OAGG;IACH,kBAHW,OAAO,GACL,IAAI,CAE8B;IAE/C;;OAEG;IACH,gBAFa,MAAM,GAAG,SAAS,CAEe;IAE9C;;OAEG;IACH,iBAFa,OAAO,CAEqC;IAEzD;;;OAGG;IACH,6BAHW,OAAO,GACL,IAAI,CAEoD;IAErE;;OAEG;IACH,YAFa,MAAM,GAAG,SAAS,CAEO;IAEtC;;OAEG;IACH,WAFa,MAAM,GAAG,SAAS,CAEK;IAEpC;;;OAGG;IACH,iBAHW,MAAM,GAAG,SAAS,GAChB,IAAI,CAE4B;IAE7C;;OAEG;IACH,oBAFa,MAAM,GAAG,SAAS,CAI9B;IAED;;;OAGG;IACH,kCAHW,MAAM,GACJ,MAAM,GAAG,SAAS,CAM9B;IAED;;OAEG;IACH,eAFa,OAAO,CAEoC;IAExD;;;;;OAKG;IACH,+CAJG;QAAsB,aAAa,EAA3B,OAAO;QACoC,MAAM,EAAjD,OAAO,oBAAoB,EAAE,OAAO;KAC5C,GAAU,MAAM,CAoIlB;CACF;2BAhXY;IAAC,MAAM,EAAE,OAAO,CAAA;CAAC;;;;;;;;;cAUhB,GAAG"}
|
|
@@ -13,6 +13,7 @@ import TableForeignKey from "./table-foreign-key.js";
|
|
|
13
13
|
* @property {boolean|object} [foreignKey] - Foreign key options or flag.
|
|
14
14
|
* @property {boolean|IndexArgType} [index] - Whether the column should be indexed.
|
|
15
15
|
* @property {boolean} [isNewColumn] - Whether this column is being added in a migration.
|
|
16
|
+
* @property {number} [limit] - Alias for maxLength (varchar length limit).
|
|
16
17
|
* @property {number} [maxLength] - Maximum length for the column value.
|
|
17
18
|
* @property {string} [notes] - Column notes or comment.
|
|
18
19
|
* @property {boolean} [null] - Whether the column allows null values.
|
|
@@ -29,11 +30,18 @@ export default class TableColumn {
|
|
|
29
30
|
*/
|
|
30
31
|
constructor(name, args) {
|
|
31
32
|
if (args) {
|
|
32
|
-
const { autoIncrement, default: columnDefault, dropColumn, foreignKey, index, isNewColumn, maxLength, notes, null: argsNull, polymorphic, precision, primaryKey, scale, type, ...restArgs } = args; // eslint-disable-line no-unused-vars
|
|
33
|
+
const { autoIncrement, default: columnDefault, dropColumn, foreignKey, index, isNewColumn, limit, maxLength, notes, null: argsNull, polymorphic, precision, primaryKey, scale, type, ...restArgs } = args; // eslint-disable-line no-unused-vars
|
|
33
34
|
if (Object.keys(args).length == 0) {
|
|
34
35
|
throw new Error("Empty args given");
|
|
35
36
|
}
|
|
36
37
|
restArgsError(restArgs);
|
|
38
|
+
// Normalize limit → maxLength for string-like types only.
|
|
39
|
+
if (limit !== undefined && maxLength === undefined) {
|
|
40
|
+
const normalizedType = typeof type === "string" ? type.toLowerCase() : "";
|
|
41
|
+
if (normalizedType === "string" || normalizedType === "text" || normalizedType === "varchar" || normalizedType === "nvarchar" || normalizedType === "char") {
|
|
42
|
+
args.maxLength = limit;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
37
45
|
}
|
|
38
46
|
this.args = args || {};
|
|
39
47
|
this.name = name;
|
|
@@ -316,4 +324,4 @@ export default class TableColumn {
|
|
|
316
324
|
return sql;
|
|
317
325
|
}
|
|
318
326
|
}
|
|
319
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-column.js","sourceRoot":"","sources":["../../../../src/database/table-data/table-column.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\n/**\n * @typedef {{unique: boolean}} IndexArgType\n */\n\nimport * as inflection from \"inflection\"\nimport restArgsError from \"../../utils/rest-args-error.js\"\nimport TableForeignKey from \"./table-foreign-key.js\"\n\n/**\n * @typedef {object} TableColumnArgsType\n * @property {boolean} [autoIncrement] - Whether the column auto-increments.\n * @property {any} [default] - Default value for the column.\n * @property {boolean} [dropColumn] - Whether the column should be dropped.\n * @property {boolean|object} [foreignKey] - Foreign key options or flag.\n * @property {boolean|IndexArgType} [index] - Whether the column should be indexed.\n * @property {boolean} [isNewColumn] - Whether this column is being added in a migration.\n * @property {number} [maxLength] - Maximum length for the column value.\n * @property {string} [notes] - Column notes or comment.\n * @property {boolean} [null] - Whether the column allows null values.\n * @property {boolean} [polymorphic] - Whether the column is polymorphic.\n * @property {number} [precision] - Numeric precision (total digits) for decimal/numeric types.\n * @property {boolean} [primaryKey] - Whether the column is a primary key.\n * @property {number} [scale] - Numeric scale (digits after decimal point) for decimal/numeric types.\n * @property {string} [type] - Column data type.\n */\n\nexport default class TableColumn {\n  /**\n   * @param {string} name - Name.\n   * @param {TableColumnArgsType} [args] - Options object.\n   */\n  constructor(name, args) {\n    if (args) {\n      const {autoIncrement, default: columnDefault, dropColumn, foreignKey, index, isNewColumn, maxLength, notes, null: argsNull, polymorphic, precision, primaryKey, scale, type, ...restArgs} = args // eslint-disable-line no-unused-vars\n\n      if (Object.keys(args).length == 0) {\n        throw new Error(\"Empty args given\")\n      }\n\n      restArgsError(restArgs)\n    }\n\n    this.args = args || {}\n    this.name = name\n  }\n\n  /**\n   * @returns {string} name\n   */\n  getName() { return this.name }\n\n  /**\n   * @returns {string | undefined} - The new name.\n   */\n  getNewName() { return this._newName }\n\n  /**\n   * @param {string} newName - New name.\n   * @returns {void} - No return value.\n   */\n  setNewName(newName) { this._newName = newName }\n\n  /**\n   * @returns {string} - The actual name.\n   */\n  getActualName() { return this.getNewName() || this.getName() }\n\n  /**\n   * @returns {boolean} - Whether auto increment.\n   */\n  getAutoIncrement() { return this.args?.autoIncrement || false }\n\n  /**\n   * @param {boolean} newAutoIncrement - New auto increment.\n   * @returns {void} - No return value.\n   */\n  setAutoIncrement(newAutoIncrement) { this.args.autoIncrement = newAutoIncrement }\n\n  /**\n   * @returns {unknown | (() => unknown)} - The default value or factory.\n   */\n  getDefault() { return this.args?.default }\n\n  /**\n   * @param {any} newDefault - New default.\n   * @returns {void} - No return value.\n   */\n  setDefault(newDefault) { this.args.default = newDefault }\n\n  /**\n   * @returns {boolean} - Whether drop column.\n   */\n  getDropColumn() { return this.args?.dropColumn || false }\n\n  /**\n   * @returns {boolean | object | undefined} - Whether foreign key.\n   */\n  getForeignKey() { return this.args?.foreignKey }\n\n  /**\n   * @param {boolean | object | undefined} newForeignKey - New foreign key.\n   * @returns {void} - No return value.\n   */\n  setForeignKey(newForeignKey) { this.args.foreignKey = newForeignKey }\n\n  /**\n   * @returns {boolean|IndexArgType} - Whether index.\n   */\n  getIndex() { return this.args?.index || false }\n\n  /**\n   * @returns {IndexArgType} - The index args.\n   */\n  getIndexArgs() {\n    if (typeof this.args?.index == \"object\") {\n      return this.args.index\n    } else {\n      return {unique: false}\n    }\n  }\n\n  getIndexUnique() {\n    const index = this.args?.index\n\n    if (typeof index == \"object\" && index.unique === true) return true\n\n    return false\n  }\n\n  /**\n   * @param {boolean|IndexArgType} newIndex - New index.\n   * @returns {void} - No return value.\n   */\n  setIndex(newIndex) { this.args.index = newIndex }\n\n  /**\n   * @returns {number | undefined} - The max length.\n   */\n  getMaxLength() { return this.args?.maxLength }\n\n  /**\n   * @param {number | undefined} newMaxLength - New max length.\n   * @returns {void} - No return value.\n   */\n  setMaxLength(newMaxLength) { this.args.maxLength = newMaxLength }\n\n  /**\n   * @returns {string | undefined} - The notes.\n   */\n  getNotes() { return this.args?.notes }\n\n  /**\n   * @param {string | undefined} newNotes - New notes.\n   * @returns {void} - No return value.\n   */\n  setNotes(newNotes) { this.args.notes = newNotes }\n\n  /**\n   * @returns {boolean | undefined} - Whether null.\n   */\n  getNull() { return this.args?.null }\n\n  /**\n   * @param {boolean} nullable - Whether nullable.\n   * @returns {void} - No return value.\n   */\n  setNull(nullable) { this.args.null = nullable }\n\n  /**\n   * @returns {number | undefined} - Numeric precision (total digits).\n   */\n  getPrecision() { return this.args?.precision }\n\n  /**\n   * @returns {boolean} - Whether primary key.\n   */\n  getPrimaryKey() { return this.args?.primaryKey || false }\n\n  /**\n   * @param {boolean} newPrimaryKey - New primary key.\n   * @returns {void} - No return value.\n   */\n  setPrimaryKey(newPrimaryKey) { this.args.primaryKey = newPrimaryKey }\n\n  /**\n   * @returns {number | undefined} - Numeric scale (digits after decimal point).\n   */\n  getScale() { return this.args?.scale }\n\n  /**\n   * @returns {string | undefined} - The type.\n   */\n  getType() { return this.args?.type }\n\n  /**\n   * @param {string | undefined} newType - New type.\n   * @returns {void} - No return value.\n   */\n  setType(newType) { this.args.type = newType }\n\n  /**\n   * @returns {string | undefined} - The type hint notes.\n   */\n  getTypeHintNotes() {\n    if (this.getType()?.toLowerCase() == \"boolean\") return \"velocious:type=boolean\"\n  }\n\n  /**\n   * @param {string} databaseType - Database type.\n   * @returns {string | undefined} - Notes for the database.\n   */\n  getNotesForDatabase(databaseType) {\n    if (![\"mysql\", \"pgsql\"].includes(databaseType)) return\n\n    return this.getNotes() || this.getTypeHintNotes()\n  }\n\n  /**\n   * @returns {boolean} - Whether new column.\n   */\n  isNewColumn() { return this.args?.isNewColumn || false }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {boolean} args.forAlterTable - Whether for alter table.\n   * @param {import(\"../drivers/base.js\").default} args.driver - Database driver instance.\n   * @returns {string} - SQL string.\n   */\n  getSQL({forAlterTable, driver, ...restArgs}) {\n    restArgsError(restArgs)\n\n    const databaseType = driver.getType()\n    const options = driver.options()\n    let maxlength = this.getMaxLength()\n    let type = this.getType()?.toUpperCase()\n\n    if (databaseType == \"pgsql\") {\n      if (type == \"DATETIME\") {\n        type = \"TIMESTAMP\"\n      } else if (type == \"TINYINT\") {\n        type = \"SMALLINT\"\n      } else if (type == \"BLOB\") {\n        type = \"BYTEA\"\n        maxlength = undefined\n      }\n    }\n\n    if (type == \"STRING\") {\n      type = \"VARCHAR\"\n      maxlength ||= 255\n    }\n    if (databaseType == \"pgsql\" && type == \"TINYINT\") {\n      type = \"SMALLINT\"\n    }\n\n    if (databaseType == \"mssql\") {\n      if (type == \"BOOLEAN\") {\n        type = \"BIT\"\n      } else if (type == \"UUID\") {\n        type = \"VARCHAR\"\n        maxlength ||= 36\n      } else if (type == \"JSON\") {\n        type = \"NVARCHAR(MAX)\"\n        maxlength = undefined\n      } else if (type == \"BLOB\") {\n        type = \"VARBINARY(MAX)\"\n        maxlength = undefined\n      }\n    }\n\n    if (databaseType == \"sqlite\" && this.getAutoIncrement() && this.getPrimaryKey()) {\n      type = \"INTEGER\"\n    }\n\n    if (databaseType == \"pgsql\" && this.getAutoIncrement() && this.getPrimaryKey()) {\n      type = \"SERIAL\"\n    }\n\n    let sql = `${options.quoteColumnName(this.getActualName())} `\n\n    if (databaseType == \"pgsql\" && forAlterTable) sql += \"TYPE \"\n    if (type) sql += type\n\n    const precision = this.getPrecision()\n    const scale = this.getScale()\n\n    if ((scale !== undefined && scale !== null) && (precision === undefined || precision === null)) {\n      throw new Error(`Column '${this.getActualName()}': scale requires precision to be set`)\n    }\n\n    if (precision !== undefined && precision !== null) {\n      sql += scale !== undefined && scale !== null ? `(${precision}, ${scale})` : `(${precision})`\n    } else if (type && maxlength !== undefined && maxlength !== null) {\n      sql += `(${maxlength})`\n    }\n\n    if (this.getAutoIncrement() && driver.shouldSetAutoIncrementWhenPrimaryKey()) {\n      if (databaseType == \"mssql\") {\n        sql += \" IDENTITY\"\n      } else if (databaseType == \"pgsql\") {\n        if (this.getAutoIncrement() && this.getPrimaryKey()) {\n          // Do nothing\n        } else {\n          throw new Error(\"pgsql auto increment must be primary key\")\n        }\n      } else {\n        sql += \" AUTO_INCREMENT\"\n      }\n    }\n\n    const defaultValue = this.getDefault()\n\n    if (typeof defaultValue == \"function\") {\n      const evaluatedDefault = defaultValue()\n\n      sql += ` DEFAULT (`\n\n      if (databaseType == \"pgsql\" && evaluatedDefault == \"UUID()\") {\n        sql += \"gen_random_uuid()\"\n      } else if (databaseType == \"mssql\" && evaluatedDefault == \"UUID()\") {\n        sql += \"NEWID()\"\n      } else {\n        sql += evaluatedDefault\n      }\n\n      sql += \")\"\n    } else if (defaultValue) {\n      sql += ` DEFAULT ${options.quote(defaultValue)}`\n    }\n\n    if (this.getPrimaryKey()) sql += \" PRIMARY KEY\"\n    if (this.getNull() === false) sql += \" NOT NULL\"\n\n    const notes = this.getNotesForDatabase(databaseType)\n\n    if (notes && databaseType == \"mysql\") {\n      sql += ` COMMENT ${options.quote(notes)}`\n    }\n\n    const foreignKey = this.getForeignKey()\n\n    if (foreignKey) {\n      let foreignKeyTable, foreignKeyColumn\n\n      if (foreignKey === true) {\n        foreignKeyColumn = \"id\"\n        foreignKeyTable = inflection.pluralize(this.getActualName().replace(/_id$/, \"\"))\n      } else if (foreignKey instanceof TableForeignKey) {\n        foreignKeyColumn = foreignKey.getReferencedColumnName()\n        foreignKeyTable = foreignKey.getReferencedTableName()\n      } else {\n        throw new Error(`Unknown foreign key type given: ${foreignKey} (${typeof foreignKey})`)\n      }\n\n      sql += ` REFERENCES ${options.quoteTableName(foreignKeyTable)}(${options.quoteColumnName(foreignKeyColumn)})`\n    }\n\n    return sql\n  }\n}\n"]}
|
|
327
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-column.js","sourceRoot":"","sources":["../../../../src/database/table-data/table-column.js"],"names":[],"mappings":"AAAA,YAAY;AAEZ;;GAEG;AAEH,OAAO,KAAK,UAAU,MAAM,YAAY,CAAA;AACxC,OAAO,aAAa,MAAM,gCAAgC,CAAA;AAC1D,OAAO,eAAe,MAAM,wBAAwB,CAAA;AAEpD;;;;;;;;;;;;;;;;;GAiBG;AAEH,MAAM,CAAC,OAAO,OAAO,WAAW;IAC9B;;;OAGG;IACH,YAAY,IAAI,EAAE,IAAI;QACpB,IAAI,IAAI,EAAE,CAAC;YACT,MAAM,EAAC,aAAa,EAAE,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,UAAU,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,QAAQ,EAAC,GAAG,IAAI,CAAA,CAAC,qCAAqC;YAE7O,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;gBAClC,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAA;YACrC,CAAC;YAED,aAAa,CAAC,QAAQ,CAAC,CAAA;YAEvB,0DAA0D;YAC1D,IAAI,KAAK,KAAK,SAAS,IAAI,SAAS,KAAK,SAAS,EAAE,CAAC;gBACnD,MAAM,cAAc,GAAG,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,CAAA;gBAEzE,IAAI,cAAc,KAAK,QAAQ,IAAI,cAAc,KAAK,MAAM,IAAI,cAAc,KAAK,SAAS,IAAI,cAAc,KAAK,UAAU,IAAI,cAAc,KAAK,MAAM,EAAE,CAAC;oBAC3J,IAAI,CAAC,SAAS,GAAG,KAAK,CAAA;gBACxB,CAAC;YACH,CAAC;QACH,CAAC;QAED,IAAI,CAAC,IAAI,GAAG,IAAI,IAAI,EAAE,CAAA;QACtB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAA;IAClB,CAAC;IAED;;OAEG;IACH,OAAO,KAAK,OAAO,IAAI,CAAC,IAAI,CAAA,CAAC,CAAC;IAE9B;;OAEG;IACH,UAAU,KAAK,OAAO,IAAI,CAAC,QAAQ,CAAA,CAAC,CAAC;IAErC;;;OAGG;IACH,UAAU,CAAC,OAAO,IAAI,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAA,CAAC,CAAC;IAE/C;;OAEG;IACH,aAAa,KAAK,OAAO,IAAI,CAAC,UAAU,EAAE,IAAI,IAAI,CAAC,OAAO,EAAE,CAAA,CAAC,CAAC;IAE9D;;OAEG;IACH,gBAAgB,KAAK,OAAO,IAAI,CAAC,IAAI,EAAE,aAAa,IAAI,KAAK,CAAA,CAAC,CAAC;IAE/D;;;OAGG;IACH,gBAAgB,CAAC,gBAAgB,IAAI,IAAI,CAAC,IAAI,CAAC,aAAa,GAAG,gBAAgB,CAAA,CAAC,CAAC;IAEjF;;OAEG;IACH,UAAU,KAAK,OAAO,IAAI,CAAC,IAAI,EAAE,OAAO,CAAA,CAAC,CAAC;IAE1C;;;OAGG;IACH,UAAU,CAAC,UAAU,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,GAAG,UAAU,CAAA,CAAC,CAAC;IAEzD;;OAEG;IACH,aAAa,KAAK,OAAO,IAAI,CAAC,IAAI,EAAE,UAAU,IAAI,KAAK,CAAA,CAAC,CAAC;IAEzD;;OAEG;IACH,aAAa,KAAK,OAAO,IAAI,CAAC,IAAI,EAAE,UAAU,CAAA,CAAC,CAAC;IAEhD;;;OAGG;IACH,aAAa,CAAC,aAAa,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,GAAG,aAAa,CAAA,CAAC,CAAC;IAErE;;OAEG;IACH,QAAQ,KAAK,OAAO,IAAI,CAAC,IAAI,EAAE,KAAK,IAAI,KAAK,CAAA,CAAC,CAAC;IAE/C;;OAEG;IACH,YAAY;QACV,IAAI,OAAO,IAAI,CAAC,IAAI,EAAE,KAAK,IAAI,QAAQ,EAAE,CAAC;YACxC,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAA;QACxB,CAAC;aAAM,CAAC;YACN,OAAO,EAAC,MAAM,EAAE,KAAK,EAAC,CAAA;QACxB,CAAC;IACH,CAAC;IAED,cAAc;QACZ,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,EAAE,KAAK,CAAA;QAE9B,IAAI,OAAO,KAAK,IAAI,QAAQ,IAAI,KAAK,CAAC,MAAM,KAAK,IAAI;YAAE,OAAO,IAAI,CAAA;QAElE,OAAO,KAAK,CAAA;IACd,CAAC;IAED;;;OAGG;IACH,QAAQ,CAAC,QAAQ,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAA,CAAC,CAAC;IAEjD;;OAEG;IACH,YAAY,KAAK,OAAO,IAAI,CAAC,IAAI,EAAE,SAAS,CAAA,CAAC,CAAC;IAE9C;;;OAGG;IACH,YAAY,CAAC,YAAY,IAAI,IAAI,CAAC,IAAI,CAAC,SAAS,GAAG,YAAY,CAAA,CAAC,CAAC;IAEjE;;OAEG;IACH,QAAQ,KAAK,OAAO,IAAI,CAAC,IAAI,EAAE,KAAK,CAAA,CAAC,CAAC;IAEtC;;;OAGG;IACH,QAAQ,CAAC,QAAQ,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAA,CAAC,CAAC;IAEjD;;OAEG;IACH,OAAO,KAAK,OAAO,IAAI,CAAC,IAAI,EAAE,IAAI,CAAA,CAAC,CAAC;IAEpC;;;OAGG;IACH,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAA,CAAC,CAAC;IAE/C;;OAEG;IACH,YAAY,KAAK,OAAO,IAAI,CAAC,IAAI,EAAE,SAAS,CAAA,CAAC,CAAC;IAE9C;;OAEG;IACH,aAAa,KAAK,OAAO,IAAI,CAAC,IAAI,EAAE,UAAU,IAAI,KAAK,CAAA,CAAC,CAAC;IAEzD;;;OAGG;IACH,aAAa,CAAC,aAAa,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,GAAG,aAAa,CAAA,CAAC,CAAC;IAErE;;OAEG;IACH,QAAQ,KAAK,OAAO,IAAI,CAAC,IAAI,EAAE,KAAK,CAAA,CAAC,CAAC;IAEtC;;OAEG;IACH,OAAO,KAAK,OAAO,IAAI,CAAC,IAAI,EAAE,IAAI,CAAA,CAAC,CAAC;IAEpC;;;OAGG;IACH,OAAO,CAAC,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG,OAAO,CAAA,CAAC,CAAC;IAE7C;;OAEG;IACH,gBAAgB;QACd,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,WAAW,EAAE,IAAI,SAAS;YAAE,OAAO,wBAAwB,CAAA;IACjF,CAAC;IAED;;;OAGG;IACH,mBAAmB,CAAC,YAAY;QAC9B,IAAI,CAAC,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC;YAAE,OAAM;QAEtD,OAAO,IAAI,CAAC,QAAQ,EAAE,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAA;IACnD,CAAC;IAED;;OAEG;IACH,WAAW,KAAK,OAAO,IAAI,CAAC,IAAI,EAAE,WAAW,IAAI,KAAK,CAAA,CAAC,CAAC;IAExD;;;;;OAKG;IACH,MAAM,CAAC,EAAC,aAAa,EAAE,MAAM,EAAE,GAAG,QAAQ,EAAC;QACzC,aAAa,CAAC,QAAQ,CAAC,CAAA;QAEvB,MAAM,YAAY,GAAG,MAAM,CAAC,OAAO,EAAE,CAAA;QACrC,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,EAAE,CAAA;QAChC,IAAI,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAA;QACnC,IAAI,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,EAAE,WAAW,EAAE,CAAA;QAExC,IAAI,YAAY,IAAI,OAAO,EAAE,CAAC;YAC5B,IAAI,IAAI,IAAI,UAAU,EAAE,CAAC;gBACvB,IAAI,GAAG,WAAW,CAAA;YACpB,CAAC;iBAAM,IAAI,IAAI,IAAI,SAAS,EAAE,CAAC;gBAC7B,IAAI,GAAG,UAAU,CAAA;YACnB,CAAC;iBAAM,IAAI,IAAI,IAAI,MAAM,EAAE,CAAC;gBAC1B,IAAI,GAAG,OAAO,CAAA;gBACd,SAAS,GAAG,SAAS,CAAA;YACvB,CAAC;QACH,CAAC;QAED,IAAI,IAAI,IAAI,QAAQ,EAAE,CAAC;YACrB,IAAI,GAAG,SAAS,CAAA;YAChB,SAAS,KAAK,GAAG,CAAA;QACnB,CAAC;QACD,IAAI,YAAY,IAAI,OAAO,IAAI,IAAI,IAAI,SAAS,EAAE,CAAC;YACjD,IAAI,GAAG,UAAU,CAAA;QACnB,CAAC;QAED,IAAI,YAAY,IAAI,OAAO,EAAE,CAAC;YAC5B,IAAI,IAAI,IAAI,SAAS,EAAE,CAAC;gBACtB,IAAI,GAAG,KAAK,CAAA;YACd,CAAC;iBAAM,IAAI,IAAI,IAAI,MAAM,EAAE,CAAC;gBAC1B,IAAI,GAAG,SAAS,CAAA;gBAChB,SAAS,KAAK,EAAE,CAAA;YAClB,CAAC;iBAAM,IAAI,IAAI,IAAI,MAAM,EAAE,CAAC;gBAC1B,IAAI,GAAG,eAAe,CAAA;gBACtB,SAAS,GAAG,SAAS,CAAA;YACvB,CAAC;iBAAM,IAAI,IAAI,IAAI,MAAM,EAAE,CAAC;gBAC1B,IAAI,GAAG,gBAAgB,CAAA;gBACvB,SAAS,GAAG,SAAS,CAAA;YACvB,CAAC;QACH,CAAC;QAED,IAAI,YAAY,IAAI,QAAQ,IAAI,IAAI,CAAC,gBAAgB,EAAE,IAAI,IAAI,CAAC,aAAa,EAAE,EAAE,CAAC;YAChF,IAAI,GAAG,SAAS,CAAA;QAClB,CAAC;QAED,IAAI,YAAY,IAAI,OAAO,IAAI,IAAI,CAAC,gBAAgB,EAAE,IAAI,IAAI,CAAC,aAAa,EAAE,EAAE,CAAC;YAC/E,IAAI,GAAG,QAAQ,CAAA;QACjB,CAAC;QAED,IAAI,GAAG,GAAG,GAAG,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,GAAG,CAAA;QAE7D,IAAI,YAAY,IAAI,OAAO,IAAI,aAAa;YAAE,GAAG,IAAI,OAAO,CAAA;QAC5D,IAAI,IAAI;YAAE,GAAG,IAAI,IAAI,CAAA;QAErB,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAA;QACrC,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAA;QAE7B,IAAI,CAAC,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,CAAC,IAAI,CAAC,SAAS,KAAK,SAAS,IAAI,SAAS,KAAK,IAAI,CAAC,EAAE,CAAC;YAC/F,MAAM,IAAI,KAAK,CAAC,WAAW,IAAI,CAAC,aAAa,EAAE,uCAAuC,CAAC,CAAA;QACzF,CAAC;QAED,IAAI,SAAS,KAAK,SAAS,IAAI,SAAS,KAAK,IAAI,EAAE,CAAC;YAClD,GAAG,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,SAAS,KAAK,KAAK,GAAG,CAAC,CAAC,CAAC,IAAI,SAAS,GAAG,CAAA;QAC9F,CAAC;aAAM,IAAI,IAAI,IAAI,SAAS,KAAK,SAAS,IAAI,SAAS,KAAK,IAAI,EAAE,CAAC;YACjE,GAAG,IAAI,IAAI,SAAS,GAAG,CAAA;QACzB,CAAC;QAED,IAAI,IAAI,CAAC,gBAAgB,EAAE,IAAI,MAAM,CAAC,oCAAoC,EAAE,EAAE,CAAC;YAC7E,IAAI,YAAY,IAAI,OAAO,EAAE,CAAC;gBAC5B,GAAG,IAAI,WAAW,CAAA;YACpB,CAAC;iBAAM,IAAI,YAAY,IAAI,OAAO,EAAE,CAAC;gBACnC,IAAI,IAAI,CAAC,gBAAgB,EAAE,IAAI,IAAI,CAAC,aAAa,EAAE,EAAE,CAAC;oBACpD,aAAa;gBACf,CAAC;qBAAM,CAAC;oBACN,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAA;gBAC7D,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,GAAG,IAAI,iBAAiB,CAAA;YAC1B,CAAC;QACH,CAAC;QAED,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,EAAE,CAAA;QAEtC,IAAI,OAAO,YAAY,IAAI,UAAU,EAAE,CAAC;YACtC,MAAM,gBAAgB,GAAG,YAAY,EAAE,CAAA;YAEvC,GAAG,IAAI,YAAY,CAAA;YAEnB,IAAI,YAAY,IAAI,OAAO,IAAI,gBAAgB,IAAI,QAAQ,EAAE,CAAC;gBAC5D,GAAG,IAAI,mBAAmB,CAAA;YAC5B,CAAC;iBAAM,IAAI,YAAY,IAAI,OAAO,IAAI,gBAAgB,IAAI,QAAQ,EAAE,CAAC;gBACnE,GAAG,IAAI,SAAS,CAAA;YAClB,CAAC;iBAAM,CAAC;gBACN,GAAG,IAAI,gBAAgB,CAAA;YACzB,CAAC;YAED,GAAG,IAAI,GAAG,CAAA;QACZ,CAAC;aAAM,IAAI,YAAY,EAAE,CAAC;YACxB,GAAG,IAAI,YAAY,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC,EAAE,CAAA;QAClD,CAAC;QAED,IAAI,IAAI,CAAC,aAAa,EAAE;YAAE,GAAG,IAAI,cAAc,CAAA;QAC/C,IAAI,IAAI,CAAC,OAAO,EAAE,KAAK,KAAK;YAAE,GAAG,IAAI,WAAW,CAAA;QAEhD,MAAM,KAAK,GAAG,IAAI,CAAC,mBAAmB,CAAC,YAAY,CAAC,CAAA;QAEpD,IAAI,KAAK,IAAI,YAAY,IAAI,OAAO,EAAE,CAAC;YACrC,GAAG,IAAI,YAAY,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAA;QAC3C,CAAC;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAA;QAEvC,IAAI,UAAU,EAAE,CAAC;YACf,IAAI,eAAe,EAAE,gBAAgB,CAAA;YAErC,IAAI,UAAU,KAAK,IAAI,EAAE,CAAC;gBACxB,gBAAgB,GAAG,IAAI,CAAA;gBACvB,eAAe,GAAG,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,CAAA;YAClF,CAAC;iBAAM,IAAI,UAAU,YAAY,eAAe,EAAE,CAAC;gBACjD,gBAAgB,GAAG,UAAU,CAAC,uBAAuB,EAAE,CAAA;gBACvD,eAAe,GAAG,UAAU,CAAC,sBAAsB,EAAE,CAAA;YACvD,CAAC;iBAAM,CAAC;gBACN,MAAM,IAAI,KAAK,CAAC,mCAAmC,UAAU,KAAK,OAAO,UAAU,GAAG,CAAC,CAAA;YACzF,CAAC;YAED,GAAG,IAAI,eAAe,OAAO,CAAC,cAAc,CAAC,eAAe,CAAC,IAAI,OAAO,CAAC,eAAe,CAAC,gBAAgB,CAAC,GAAG,CAAA;QAC/G,CAAC;QAED,OAAO,GAAG,CAAA;IACZ,CAAC;CACF","sourcesContent":["// @ts-check\n\n/**\n * @typedef {{unique: boolean}} IndexArgType\n */\n\nimport * as inflection from \"inflection\"\nimport restArgsError from \"../../utils/rest-args-error.js\"\nimport TableForeignKey from \"./table-foreign-key.js\"\n\n/**\n * @typedef {object} TableColumnArgsType\n * @property {boolean} [autoIncrement] - Whether the column auto-increments.\n * @property {any} [default] - Default value for the column.\n * @property {boolean} [dropColumn] - Whether the column should be dropped.\n * @property {boolean|object} [foreignKey] - Foreign key options or flag.\n * @property {boolean|IndexArgType} [index] - Whether the column should be indexed.\n * @property {boolean} [isNewColumn] - Whether this column is being added in a migration.\n * @property {number} [limit] - Alias for maxLength (varchar length limit).\n * @property {number} [maxLength] - Maximum length for the column value.\n * @property {string} [notes] - Column notes or comment.\n * @property {boolean} [null] - Whether the column allows null values.\n * @property {boolean} [polymorphic] - Whether the column is polymorphic.\n * @property {number} [precision] - Numeric precision (total digits) for decimal/numeric types.\n * @property {boolean} [primaryKey] - Whether the column is a primary key.\n * @property {number} [scale] - Numeric scale (digits after decimal point) for decimal/numeric types.\n * @property {string} [type] - Column data type.\n */\n\nexport default class TableColumn {\n  /**\n   * @param {string} name - Name.\n   * @param {TableColumnArgsType} [args] - Options object.\n   */\n  constructor(name, args) {\n    if (args) {\n      const {autoIncrement, default: columnDefault, dropColumn, foreignKey, index, isNewColumn, limit, maxLength, notes, null: argsNull, polymorphic, precision, primaryKey, scale, type, ...restArgs} = args // eslint-disable-line no-unused-vars\n\n      if (Object.keys(args).length == 0) {\n        throw new Error(\"Empty args given\")\n      }\n\n      restArgsError(restArgs)\n\n      // Normalize limit → maxLength for string-like types only.\n      if (limit !== undefined && maxLength === undefined) {\n        const normalizedType = typeof type === \"string\" ? type.toLowerCase() : \"\"\n\n        if (normalizedType === \"string\" || normalizedType === \"text\" || normalizedType === \"varchar\" || normalizedType === \"nvarchar\" || normalizedType === \"char\") {\n          args.maxLength = limit\n        }\n      }\n    }\n\n    this.args = args || {}\n    this.name = name\n  }\n\n  /**\n   * @returns {string} name\n   */\n  getName() { return this.name }\n\n  /**\n   * @returns {string | undefined} - The new name.\n   */\n  getNewName() { return this._newName }\n\n  /**\n   * @param {string} newName - New name.\n   * @returns {void} - No return value.\n   */\n  setNewName(newName) { this._newName = newName }\n\n  /**\n   * @returns {string} - The actual name.\n   */\n  getActualName() { return this.getNewName() || this.getName() }\n\n  /**\n   * @returns {boolean} - Whether auto increment.\n   */\n  getAutoIncrement() { return this.args?.autoIncrement || false }\n\n  /**\n   * @param {boolean} newAutoIncrement - New auto increment.\n   * @returns {void} - No return value.\n   */\n  setAutoIncrement(newAutoIncrement) { this.args.autoIncrement = newAutoIncrement }\n\n  /**\n   * @returns {unknown | (() => unknown)} - The default value or factory.\n   */\n  getDefault() { return this.args?.default }\n\n  /**\n   * @param {any} newDefault - New default.\n   * @returns {void} - No return value.\n   */\n  setDefault(newDefault) { this.args.default = newDefault }\n\n  /**\n   * @returns {boolean} - Whether drop column.\n   */\n  getDropColumn() { return this.args?.dropColumn || false }\n\n  /**\n   * @returns {boolean | object | undefined} - Whether foreign key.\n   */\n  getForeignKey() { return this.args?.foreignKey }\n\n  /**\n   * @param {boolean | object | undefined} newForeignKey - New foreign key.\n   * @returns {void} - No return value.\n   */\n  setForeignKey(newForeignKey) { this.args.foreignKey = newForeignKey }\n\n  /**\n   * @returns {boolean|IndexArgType} - Whether index.\n   */\n  getIndex() { return this.args?.index || false }\n\n  /**\n   * @returns {IndexArgType} - The index args.\n   */\n  getIndexArgs() {\n    if (typeof this.args?.index == \"object\") {\n      return this.args.index\n    } else {\n      return {unique: false}\n    }\n  }\n\n  getIndexUnique() {\n    const index = this.args?.index\n\n    if (typeof index == \"object\" && index.unique === true) return true\n\n    return false\n  }\n\n  /**\n   * @param {boolean|IndexArgType} newIndex - New index.\n   * @returns {void} - No return value.\n   */\n  setIndex(newIndex) { this.args.index = newIndex }\n\n  /**\n   * @returns {number | undefined} - The max length.\n   */\n  getMaxLength() { return this.args?.maxLength }\n\n  /**\n   * @param {number | undefined} newMaxLength - New max length.\n   * @returns {void} - No return value.\n   */\n  setMaxLength(newMaxLength) { this.args.maxLength = newMaxLength }\n\n  /**\n   * @returns {string | undefined} - The notes.\n   */\n  getNotes() { return this.args?.notes }\n\n  /**\n   * @param {string | undefined} newNotes - New notes.\n   * @returns {void} - No return value.\n   */\n  setNotes(newNotes) { this.args.notes = newNotes }\n\n  /**\n   * @returns {boolean | undefined} - Whether null.\n   */\n  getNull() { return this.args?.null }\n\n  /**\n   * @param {boolean} nullable - Whether nullable.\n   * @returns {void} - No return value.\n   */\n  setNull(nullable) { this.args.null = nullable }\n\n  /**\n   * @returns {number | undefined} - Numeric precision (total digits).\n   */\n  getPrecision() { return this.args?.precision }\n\n  /**\n   * @returns {boolean} - Whether primary key.\n   */\n  getPrimaryKey() { return this.args?.primaryKey || false }\n\n  /**\n   * @param {boolean} newPrimaryKey - New primary key.\n   * @returns {void} - No return value.\n   */\n  setPrimaryKey(newPrimaryKey) { this.args.primaryKey = newPrimaryKey }\n\n  /**\n   * @returns {number | undefined} - Numeric scale (digits after decimal point).\n   */\n  getScale() { return this.args?.scale }\n\n  /**\n   * @returns {string | undefined} - The type.\n   */\n  getType() { return this.args?.type }\n\n  /**\n   * @param {string | undefined} newType - New type.\n   * @returns {void} - No return value.\n   */\n  setType(newType) { this.args.type = newType }\n\n  /**\n   * @returns {string | undefined} - The type hint notes.\n   */\n  getTypeHintNotes() {\n    if (this.getType()?.toLowerCase() == \"boolean\") return \"velocious:type=boolean\"\n  }\n\n  /**\n   * @param {string} databaseType - Database type.\n   * @returns {string | undefined} - Notes for the database.\n   */\n  getNotesForDatabase(databaseType) {\n    if (![\"mysql\", \"pgsql\"].includes(databaseType)) return\n\n    return this.getNotes() || this.getTypeHintNotes()\n  }\n\n  /**\n   * @returns {boolean} - Whether new column.\n   */\n  isNewColumn() { return this.args?.isNewColumn || false }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {boolean} args.forAlterTable - Whether for alter table.\n   * @param {import(\"../drivers/base.js\").default} args.driver - Database driver instance.\n   * @returns {string} - SQL string.\n   */\n  getSQL({forAlterTable, driver, ...restArgs}) {\n    restArgsError(restArgs)\n\n    const databaseType = driver.getType()\n    const options = driver.options()\n    let maxlength = this.getMaxLength()\n    let type = this.getType()?.toUpperCase()\n\n    if (databaseType == \"pgsql\") {\n      if (type == \"DATETIME\") {\n        type = \"TIMESTAMP\"\n      } else if (type == \"TINYINT\") {\n        type = \"SMALLINT\"\n      } else if (type == \"BLOB\") {\n        type = \"BYTEA\"\n        maxlength = undefined\n      }\n    }\n\n    if (type == \"STRING\") {\n      type = \"VARCHAR\"\n      maxlength ||= 255\n    }\n    if (databaseType == \"pgsql\" && type == \"TINYINT\") {\n      type = \"SMALLINT\"\n    }\n\n    if (databaseType == \"mssql\") {\n      if (type == \"BOOLEAN\") {\n        type = \"BIT\"\n      } else if (type == \"UUID\") {\n        type = \"VARCHAR\"\n        maxlength ||= 36\n      } else if (type == \"JSON\") {\n        type = \"NVARCHAR(MAX)\"\n        maxlength = undefined\n      } else if (type == \"BLOB\") {\n        type = \"VARBINARY(MAX)\"\n        maxlength = undefined\n      }\n    }\n\n    if (databaseType == \"sqlite\" && this.getAutoIncrement() && this.getPrimaryKey()) {\n      type = \"INTEGER\"\n    }\n\n    if (databaseType == \"pgsql\" && this.getAutoIncrement() && this.getPrimaryKey()) {\n      type = \"SERIAL\"\n    }\n\n    let sql = `${options.quoteColumnName(this.getActualName())} `\n\n    if (databaseType == \"pgsql\" && forAlterTable) sql += \"TYPE \"\n    if (type) sql += type\n\n    const precision = this.getPrecision()\n    const scale = this.getScale()\n\n    if ((scale !== undefined && scale !== null) && (precision === undefined || precision === null)) {\n      throw new Error(`Column '${this.getActualName()}': scale requires precision to be set`)\n    }\n\n    if (precision !== undefined && precision !== null) {\n      sql += scale !== undefined && scale !== null ? `(${precision}, ${scale})` : `(${precision})`\n    } else if (type && maxlength !== undefined && maxlength !== null) {\n      sql += `(${maxlength})`\n    }\n\n    if (this.getAutoIncrement() && driver.shouldSetAutoIncrementWhenPrimaryKey()) {\n      if (databaseType == \"mssql\") {\n        sql += \" IDENTITY\"\n      } else if (databaseType == \"pgsql\") {\n        if (this.getAutoIncrement() && this.getPrimaryKey()) {\n          // Do nothing\n        } else {\n          throw new Error(\"pgsql auto increment must be primary key\")\n        }\n      } else {\n        sql += \" AUTO_INCREMENT\"\n      }\n    }\n\n    const defaultValue = this.getDefault()\n\n    if (typeof defaultValue == \"function\") {\n      const evaluatedDefault = defaultValue()\n\n      sql += ` DEFAULT (`\n\n      if (databaseType == \"pgsql\" && evaluatedDefault == \"UUID()\") {\n        sql += \"gen_random_uuid()\"\n      } else if (databaseType == \"mssql\" && evaluatedDefault == \"UUID()\") {\n        sql += \"NEWID()\"\n      } else {\n        sql += evaluatedDefault\n      }\n\n      sql += \")\"\n    } else if (defaultValue) {\n      sql += ` DEFAULT ${options.quote(defaultValue)}`\n    }\n\n    if (this.getPrimaryKey()) sql += \" PRIMARY KEY\"\n    if (this.getNull() === false) sql += \" NOT NULL\"\n\n    const notes = this.getNotesForDatabase(databaseType)\n\n    if (notes && databaseType == \"mysql\") {\n      sql += ` COMMENT ${options.quote(notes)}`\n    }\n\n    const foreignKey = this.getForeignKey()\n\n    if (foreignKey) {\n      let foreignKeyTable, foreignKeyColumn\n\n      if (foreignKey === true) {\n        foreignKeyColumn = \"id\"\n        foreignKeyTable = inflection.pluralize(this.getActualName().replace(/_id$/, \"\"))\n      } else if (foreignKey instanceof TableForeignKey) {\n        foreignKeyColumn = foreignKey.getReferencedColumnName()\n        foreignKeyTable = foreignKey.getReferencedTableName()\n      } else {\n        throw new Error(`Unknown foreign key type given: ${foreignKey} (${typeof foreignKey})`)\n      }\n\n      sql += ` REFERENCES ${options.quoteTableName(foreignKeyTable)}(${options.quoteColumnName(foreignKeyColumn)})`\n    }\n\n    return sql\n  }\n}\n"]}
|