velocious 1.0.365 → 1.0.366

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.
@@ -20,6 +20,7 @@ import CliCommandsDbSeed from "./node/cli/commands/db/seed.js";
20
20
  import CliCommandsRunner from "./node/cli/commands/runner.js";
21
21
  import CliCommandsRunScript from "./node/cli/commands/run-script.js";
22
22
  import frontendModelCommandRouteHook from "../routes/hooks/frontend-model-command-route-hook.js";
23
+ import { FRAMEWORK_SOURCE_DIRECTORY } from "../utils/backtrace-cleaner-node.js";
23
24
  import { dirname } from "path";
24
25
  import { fileURLToPath } from "url";
25
26
  import fs from "fs/promises";
@@ -52,6 +53,12 @@ export default class VelociousEnvironmentHandlerNode extends Base {
52
53
  _timezoneAsyncLocalStorage = NodeAsyncLocalStorage ? new NodeAsyncLocalStorage() : undefined;
53
54
  /** @type {import("./base.js").CommandFileObjectType[] | undefined} */
54
55
  _findCommandsResult = undefined;
56
+ /**
57
+ * @returns {string | undefined} - Velocious source directory used to filter framework stack frames.
58
+ */
59
+ getFrameworkSourceDirectory() {
60
+ return FRAMEWORK_SOURCE_DIRECTORY;
61
+ }
55
62
  /**
56
63
  * Auto-discovers resource classes from src/resources/ in each backend project.
57
64
  * @param {import("../configuration.js").default} configuration - Configuration instance.
@@ -663,4 +670,4 @@ export default class VelociousEnvironmentHandlerNode extends Base {
663
670
  return sqlByIdentifier;
664
671
  }
665
672
  }
666
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.js","sourceRoot":"","sources":["../../../src/environment-handlers/node.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport Base from \"./base.js\"\nimport CliCommandsDestroyMigration from \"./node/cli/commands/destroy/migration.js\"\nimport CliCommandsInit from \"./node/cli/commands/init.js\"\nimport CliCommandsGenerateBaseModels from \"./node/cli/commands/generate/base-models.js\"\nimport CliCommandsGenerateFrontendModels from \"./node/cli/commands/generate/frontend-models.js\"\nimport CliCommandsGenerateMigration from \"./node/cli/commands/generate/migration.js\"\nimport CliCommandsGenerateModel from \"./node/cli/commands/generate/model.js\"\nimport CliCommandsRoutes from \"./node/cli/commands/routes.js\"\nimport CliCommandsServer from \"./node/cli/commands/server.js\"\nimport CliCommandsTest from \"./node/cli/commands/test.js\"\nimport CliCommandsBackgroundJobsMain from \"./node/cli/commands/background-jobs-main.js\"\nimport CliCommandsBackgroundJobsWorker from \"./node/cli/commands/background-jobs-worker.js\"\nimport CliCommandsBackgroundJobsRunner from \"./node/cli/commands/background-jobs-runner.js\"\nimport CliCommandsBeacon from \"./node/cli/commands/beacon.js\"\nimport CliCommandsConsole from \"./node/cli/commands/console.js\"\nimport CliCommandsDbSchemaDump from \"./node/cli/commands/db/schema/dump.js\"\nimport CliCommandsDbSchemaLoad from \"./node/cli/commands/db/schema/load.js\"\nimport CliCommandsDbSeed from \"./node/cli/commands/db/seed.js\"\nimport CliCommandsRunner from \"./node/cli/commands/runner.js\"\nimport CliCommandsRunScript from \"./node/cli/commands/run-script.js\"\nimport frontendModelCommandRouteHook from \"../routes/hooks/frontend-model-command-route-hook.js\"\nimport {dirname} from \"path\"\nimport {fileURLToPath} from \"url\"\nimport fs from \"fs/promises\"\nimport * as inflection from \"inflection\"\nimport path from \"path\"\nimport {AsyncLocalStorage as NodeAsyncLocalStorage} from \"node:async_hooks\"\nimport toImportSpecifier from \"../utils/to-import-specifier.js\"\n\n/** @typedef {{ability?: import(\"../authorization/ability.js\").default, offsetMinutes: number, requestTiming?: import(\"../http-server/client/request-timing.js\").default, tenant?: unknown}} TimezoneStore */\n\n/**\n * @param {string} filePath - Input file path.\n * @param {string[]} allowedPathPrefixes - Allowed path prefixes.\n * @returns {boolean} - Whether input path is inside an allowed prefix.\n */\nfunction pathWithinAllowedPrefixes(filePath, allowedPathPrefixes) {\n  const resolvedPath = path.resolve(filePath)\n\n  return allowedPathPrefixes.some((allowedPrefix) => {\n    const resolvedPrefix = path.resolve(allowedPrefix)\n    const relativePath = path.relative(resolvedPrefix, resolvedPath)\n\n    if (!relativePath) return true\n    if (relativePath.startsWith(\"..\")) return false\n    if (path.isAbsolute(relativePath)) return false\n\n    return true\n  })\n}\n\nexport default class VelociousEnvironmentHandlerNode extends Base{\n  /** @type {import(\"node:async_hooks\").AsyncLocalStorage<TimezoneStore> | undefined} */\n  _timezoneAsyncLocalStorage = NodeAsyncLocalStorage ? new NodeAsyncLocalStorage() : undefined\n\n  /** @type {import(\"./base.js\").CommandFileObjectType[] | undefined} */\n  _findCommandsResult = undefined\n\n  /**\n   * Auto-discovers resource classes from src/resources/ in each backend project.\n   * @param {import(\"../configuration.js\").default} configuration - Configuration instance.\n   * @returns {Promise<void>}\n   */\n  async autoDiscoverResources(configuration) {\n    const {frontendModelResourceDefinitionIsClass} = await import(\"../frontend-models/resource-definition.js\")\n    const backendProjects = configuration.getBackendProjects()\n\n    for (const backendProject of backendProjects) {\n      if (backendProject.frontendModels) continue\n\n      const resourcesDir = path.join(backendProject.path, \"src\", \"resources\")\n      let files\n\n      try {\n        files = await fs.readdir(resourcesDir)\n      } catch {\n        continue\n      }\n\n      /** @type {Record<string, any>} */\n      const discovered = {}\n\n      for (const file of files) {\n        if (!file.endsWith(\".js\") && !file.endsWith(\".mjs\")) continue\n        if (file.startsWith(\"frontend-model-resources\")) continue\n\n        const filePath = path.join(resourcesDir, file)\n        const imported = await import(filePath)\n        const ResourceClass = imported.default\n\n        if (!frontendModelResourceDefinitionIsClass(ResourceClass)) continue\n\n        const baseName = file.replace(/\\.(js|mjs)$/, \"\")\n        const modelName = baseName.replace(/-resource$/, \"\")\n          .split(\"-\")\n          .map((/** @type {string} */ part) => part.charAt(0).toUpperCase() + part.slice(1))\n          .join(\"\")\n\n        discovered[modelName] = ResourceClass\n      }\n\n      if (Object.keys(discovered).length > 0) {\n        backendProject.frontendModels = discovered\n      }\n    }\n  }\n\n  /**\n   * @param {import(\"../configuration.js\").default} newConfiguration - New configuration.\n   * @returns {void} - No return value.\n   */\n  setConfiguration(newConfiguration) {\n    super.setConfiguration(newConfiguration)\n\n    if (!newConfiguration.getRouteResolverHooks().includes(frontendModelCommandRouteHook)) {\n      newConfiguration.addRouteResolverHook(frontendModelCommandRouteHook)\n    }\n  }\n\n  /**\n   * @param {string} filePath - File path.\n   * @returns {Promise<Buffer>} - File bytes.\n   */\n  async readAttachmentInputFile(filePath) {\n    return await fs.readFile(filePath)\n  }\n\n  /**\n   * @param {object} args - Args.\n   * @param {string[]} args.allowedPathPrefixes - Allowed path prefixes.\n   * @param {string} args.inputPath - Input path.\n   * @returns {Promise<{buffer: Buffer, filePath: string}>} - Resolved path and bytes.\n   */\n  async resolveAttachmentInputPath({allowedPathPrefixes, inputPath}) {\n    const filePath = path.resolve(inputPath)\n    const prefixes = Array.isArray(allowedPathPrefixes)\n      ? allowedPathPrefixes.filter((entry) => typeof entry === \"string\" && entry.length > 0)\n      : []\n\n    if (prefixes.length > 0 && !pathWithinAllowedPrefixes(filePath, prefixes)) {\n      throw new Error(\"Attachment path is outside allowed directories\")\n    }\n\n    const buffer = await this.readAttachmentInputFile(filePath)\n\n    return {buffer, filePath}\n  }\n\n  /**\n   * @returns {Promise<Array<import(\"./base.js\").CommandFileObjectType>>} - Resolves with the commands.\n   */\n  async findCommands() {\n    this._findCommandsResult ||= await this._actualFindCommands()\n\n    if (!this._findCommandsResult) throw new Error(\"Could not get commands\")\n\n    return this._findCommandsResult\n  }\n\n  /**\n   * @param {number} offsetMinutes - Offset in minutes (Date#getTimezoneOffset).\n   * @param {() => Promise<any>} callback - Callback to run.\n   * @returns {Promise<any>} - Result of the callback.\n   */\n  async runWithTimezoneOffset(offsetMinutes, callback) {\n    if (!this._timezoneAsyncLocalStorage) {\n      return await callback()\n    }\n\n    const existingStore = this._timezoneAsyncLocalStorage.getStore()\n\n    return await this._timezoneAsyncLocalStorage.run({\n      ability: existingStore?.ability,\n      offsetMinutes,\n      requestTiming: existingStore?.requestTiming,\n      tenant: existingStore?.tenant\n    }, callback)\n  }\n\n  /**\n   * @param {number} offsetMinutes - Offset in minutes (Date#getTimezoneOffset).\n   * @returns {void} - No return value.\n   */\n  setTimezoneOffset(offsetMinutes) {\n    if (!this._timezoneAsyncLocalStorage) return\n\n    const store = this._timezoneAsyncLocalStorage.getStore()\n\n    if (store) {\n      store.offsetMinutes = offsetMinutes\n    } else {\n      const existingStore = this._timezoneAsyncLocalStorage.getStore()\n\n      this._timezoneAsyncLocalStorage.enterWith({\n        ability: existingStore?.ability,\n        offsetMinutes,\n        requestTiming: existingStore?.requestTiming,\n        tenant: existingStore?.tenant\n      })\n    }\n  }\n\n  /**\n   * @param {import(\"../configuration.js\").default | undefined} configuration - Configuration instance.\n   * @returns {number} - Offset in minutes.\n   */\n  getTimezoneOffsetMinutes(configuration) {\n    if (this._timezoneAsyncLocalStorage) {\n      const store = this._timezoneAsyncLocalStorage.getStore()\n\n      if (store && typeof store.offsetMinutes === \"number\") {\n        return store.offsetMinutes\n      }\n    }\n\n    return super.getTimezoneOffsetMinutes(configuration)\n  }\n\n  /**\n   * @param {import(\"../authorization/ability.js\").default | undefined} ability - Ability to set for callback scope.\n   * @param {() => Promise<any>} callback - Callback.\n   * @returns {Promise<any>} - Callback result.\n   */\n  async runWithAbility(ability, callback) {\n    if (!this._timezoneAsyncLocalStorage) {\n      return await super.runWithAbility(ability, callback)\n    }\n\n    const existingStore = this._timezoneAsyncLocalStorage.getStore()\n\n    return await this._timezoneAsyncLocalStorage.run({\n      ability,\n      offsetMinutes: existingStore?.offsetMinutes ?? this.getTimezoneOffsetMinutes(this.getConfiguration()),\n      requestTiming: existingStore?.requestTiming,\n      tenant: existingStore?.tenant\n    }, callback)\n  }\n\n  /**\n   * @param {import(\"../authorization/ability.js\").default | undefined} ability - Ability to set.\n   * @returns {void} - No return value.\n   */\n  setCurrentAbility(ability) {\n    if (!this._timezoneAsyncLocalStorage) {\n      super.setCurrentAbility(ability)\n      return\n    }\n\n    const existingStore = this._timezoneAsyncLocalStorage.getStore()\n\n    if (existingStore) {\n      existingStore.ability = ability\n    } else {\n      this._timezoneAsyncLocalStorage.enterWith({\n        ability,\n        offsetMinutes: this.getTimezoneOffsetMinutes(this.getConfiguration()),\n        requestTiming: undefined,\n        tenant: undefined\n      })\n    }\n  }\n\n  /**\n   * @returns {import(\"../authorization/ability.js\").default | undefined} - Current ability.\n   */\n  getCurrentAbility() {\n    if (!this._timezoneAsyncLocalStorage) {\n      return super.getCurrentAbility()\n    }\n\n    return this._timezoneAsyncLocalStorage.getStore()?.ability\n  }\n\n  /**\n   * @param {import(\"../http-server/client/request-timing.js\").default | undefined} requestTiming - Request timing collector.\n   * @param {() => Promise<any>} callback - Callback.\n   * @returns {Promise<any>} - Callback result.\n   */\n  async runWithRequestTiming(requestTiming, callback) {\n    if (!this._timezoneAsyncLocalStorage) {\n      return await super.runWithRequestTiming(requestTiming, callback)\n    }\n\n    const existingStore = this._timezoneAsyncLocalStorage.getStore()\n\n    return await this._timezoneAsyncLocalStorage.run({\n      ability: existingStore?.ability,\n      offsetMinutes: existingStore?.offsetMinutes ?? this.getTimezoneOffsetMinutes(this.getConfiguration()),\n      requestTiming,\n      tenant: existingStore?.tenant\n    }, callback)\n  }\n\n  /**\n   * @returns {import(\"../http-server/client/request-timing.js\").default | undefined} - Current request timing collector.\n   */\n  getCurrentRequestTiming() {\n    if (!this._timezoneAsyncLocalStorage) {\n      return super.getCurrentRequestTiming()\n    }\n\n    return this._timezoneAsyncLocalStorage.getStore()?.requestTiming\n  }\n\n  /**\n   * @param {unknown} tenant - Tenant to set for callback scope.\n   * @param {() => Promise<any>} callback - Callback.\n   * @returns {Promise<any>} - Callback result.\n   */\n  async runWithTenant(tenant, callback) {\n    if (!this._timezoneAsyncLocalStorage) {\n      return await super.runWithTenant(tenant, callback)\n    }\n\n    const existingStore = this._timezoneAsyncLocalStorage.getStore()\n\n    return await this._timezoneAsyncLocalStorage.run({\n      ability: existingStore?.ability,\n      offsetMinutes: existingStore?.offsetMinutes ?? this.getTimezoneOffsetMinutes(this.getConfiguration()),\n      requestTiming: existingStore?.requestTiming,\n      tenant\n    }, callback)\n  }\n\n  /**\n   * @param {unknown} tenant - Tenant to set.\n   * @returns {void} - No return value.\n   */\n  setCurrentTenant(tenant) {\n    if (!this._timezoneAsyncLocalStorage) {\n      super.setCurrentTenant(tenant)\n      return\n    }\n\n    const existingStore = this._timezoneAsyncLocalStorage.getStore()\n\n    if (existingStore) {\n      existingStore.tenant = tenant\n    } else {\n      this._timezoneAsyncLocalStorage.enterWith({\n        ability: undefined,\n        offsetMinutes: this.getTimezoneOffsetMinutes(this.getConfiguration()),\n        requestTiming: undefined,\n        tenant\n      })\n    }\n  }\n\n  /**\n   * @returns {unknown} - Current tenant.\n   */\n  getCurrentTenant() {\n    if (!this._timezoneAsyncLocalStorage) {\n      return super.getCurrentTenant()\n    }\n\n    return this._timezoneAsyncLocalStorage.getStore()?.tenant\n  }\n\n  /**\n   * @returns {Promise<Array<import(\"./base.js\").CommandFileObjectType>>} - Resolves with discovered command files.\n   */\n  async _actualFindCommands() {\n    const basePath = await this.getBasePath()\n    const commandFiles = fs.glob(`${basePath}/src/cli/commands/**/*.js`)\n    const commands = []\n\n    for await (const aFilePath of commandFiles) {\n      const commandName = this.commandNameFromFilePath(aFilePath)\n\n      commands.push({name: commandName, file: aFilePath})\n    }\n\n    return commands\n  }\n\n  /**\n   * @param {string} filePath - Full command file path.\n   * @returns {string} - Parsed command name.\n   */\n  commandNameFromFilePath(filePath) {\n    const aFilePathParts = filePath.split(/[\\\\/]/)\n    const commandPathLocation = aFilePathParts.indexOf(\"commands\")\n\n    if (commandPathLocation === -1) {\n      throw new Error(`Could not parse command file path: ${filePath}`)\n    }\n\n    const commandParts = aFilePathParts.slice(commandPathLocation + 1)\n    const lastPart = commandParts[commandParts.length - 1]\n    let name, paths\n\n    if (lastPart == \"index.js\") {\n      name = commandParts[commandParts.length - 2]\n      paths = commandParts.slice(0, -2)\n    } else {\n      name = lastPart.replace(\".js\", \"\")\n      paths = commandParts.slice(0, -1)\n    }\n\n    return `${paths.join(\":\")}${paths.length > 0 ? \":\" : \"\"}${name}`\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsInit(command) {\n    return await this.forwardCommand(command, CliCommandsInit)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsMigrationGenerate(command) {\n    return await this.forwardCommand(command, CliCommandsGenerateMigration)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsMigrationDestroy(command) {\n    return await this.forwardCommand(command, CliCommandsDestroyMigration)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsGenerateBaseModels(command) {\n    return await this.forwardCommand(command, CliCommandsGenerateBaseModels)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsGenerateFrontendModels(command) {\n    return await this.forwardCommand(command, CliCommandsGenerateFrontendModels)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsGenerateModel(command) {\n    return await this.forwardCommand(command, CliCommandsGenerateModel)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsRoutes(command) {\n    return await this.forwardCommand(command, CliCommandsRoutes)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsConsole(command) {\n    return await this.forwardCommand(command, CliCommandsConsole)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsServer(command) {\n    return await this.forwardCommand(command, CliCommandsServer)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsTest(command) {\n    return await this.forwardCommand(command, CliCommandsTest)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsBackgroundJobsMain(command) {\n    return await this.forwardCommand(command, CliCommandsBackgroundJobsMain)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsBackgroundJobsWorker(command) {\n    return await this.forwardCommand(command, CliCommandsBackgroundJobsWorker)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsBackgroundJobsRunner(command) {\n    return await this.forwardCommand(command, CliCommandsBackgroundJobsRunner)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsBeacon(command) {\n    return await this.forwardCommand(command, CliCommandsBeacon)\n  }\n\n  /** @returns {Promise<typeof import(\"../beacon/client.js\").default>} - Beacon client class. */\n  async loadBeaconClient() {\n    const {default: BeaconClient} = await import(\"../beacon/client.js\")\n\n    return BeaconClient\n  }\n\n  /** @returns {Promise<typeof import(\"../beacon/in-process-client.js\").default>} - In-process client class. */\n  async loadInProcessBeaconClient() {\n    const {default: InProcessBeaconClient} = await import(\"../beacon/in-process-client.js\")\n\n    return InProcessBeaconClient\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsDbSchemaDump(command) {\n    return await this.forwardCommand(command, CliCommandsDbSchemaDump)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsDbSchemaLoad(command) {\n    return await this.forwardCommand(command, CliCommandsDbSchemaLoad)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsDbSeed(command) {\n    return await this.forwardCommand(command, CliCommandsDbSeed)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsRunner(command) {\n    return await this.forwardCommand(command, CliCommandsRunner)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsRunScript(command) {\n    return await this.forwardCommand(command, CliCommandsRunScript)\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {string[]} args.commandParts - Command parts.\n   * @returns {Promise<typeof import (\"../cli/base-command.js\").default>} - Resolves with the require command.\n   */\n  async requireCommand({commandParts}) {\n    const commands = await this.findCommands()\n    const commandName = commandParts.join(\":\")\n    const command = commands.find((aCommand) => aCommand.name === commandName)\n\n    if (!command) {\n      const possibleCommands = commands.map(aCommand => aCommand.name)\n\n      throw new Error(`Unknown command: ${commandParts.join(\":\")} which should have been one of: ${possibleCommands.sort().join(\", \")}`)\n    }\n\n    const commandClassImport = await import(toImportSpecifier(command.file))\n    const CommandClass = commandClassImport.default\n\n    return CommandClass\n  }\n\n  /**\n   * @returns {Promise<Array<import(\"./base.js\").MigrationObjectType>>} - Resolves with the migrations.\n   */\n  async findMigrations() {\n    const migrationsPath = `${this.getConfiguration().getDirectory()}/src/database/migrations`\n    const glob = await fs.glob(`${migrationsPath}/**/*.js`)\n    let files = []\n\n    for await (const fullPath of glob) {\n      const file = await path.basename(fullPath)\n\n      const match = file.match(/^(\\d{14})-(.+)\\.js$/)\n\n      if (!match) continue\n\n      const date = parseInt(match[1])\n      const migrationName = match[2]\n      const migrationClassName = inflection.camelize(migrationName.replaceAll(\"-\", \"_\"))\n\n      files.push({\n        file,\n        fullPath: `${migrationsPath}/${file}`,\n        date,\n        migrationClassName\n      })\n    }\n\n    files = files.sort((migration1, migration2) => migration1.date - migration2.date)\n\n    return files\n  }\n\n  /**\n   * @returns {Promise<import(\"../routes/index.js\").default>} - Resolves with the import application routes.\n   */\n  async importApplicationRoutes() {\n    const routesImport = await import(toImportSpecifier(`${this.getConfiguration().getDirectory()}/src/config/routes.js`))\n\n    return routesImport.default\n  }\n\n  /**\n   * @returns {Promise<string>} - Resolves with the velocious path.\n   */\n  async getVelociousPath() {\n    if (!this._velociousPath) {\n      const __filename = fileURLToPath(import.meta.url)\n      const __dirname = dirname(__filename)\n\n      this._velociousPath = await fs.realpath(`${__dirname}/../..`)\n    }\n\n    return this._velociousPath\n  }\n\n  /**\n   * @param {string[]} testFiles - Test files.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async importTestFiles(testFiles) {\n    for (const testFile of testFiles) {\n      await import(toImportSpecifier(testFile))\n    }\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {import(\"../configuration.js\").default} args.configuration - Configuration instance.\n   * @returns {string} - The default log directory.\n   */\n  getDefaultLogDirectory({configuration}) {\n    return path.join(configuration.getDirectory(), \"log\")\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {import(\"../configuration.js\").default} args.configuration - Configuration instance.\n   * @param {string | undefined} args.directory - Directory path.\n   * @param {string} args.environment - Environment.\n   * @returns {string | undefined} - The log file path.\n   */\n  getLogFilePath({configuration, directory, environment}) {\n    const actualDirectory = directory || configuration?.getDirectory?.()\n\n    if (!actualDirectory) return undefined\n\n    return path.join(actualDirectory, `${environment}.log`)\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {string} args.filePath - File path.\n   * @param {string} args.message - Message text.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async writeLogToFile({filePath, message}) {\n    await fs.mkdir(path.dirname(filePath), {recursive: true})\n    await fs.appendFile(filePath, `${message}\\n`, \"utf8\")\n  }\n\n  async importTestingConfigPath() {\n    const testingConfigPath = this.getConfiguration().getTesting()\n\n    if (!testingConfigPath) return\n\n    const testingImport = await import(toImportSpecifier(testingConfigPath))\n    const testingDefault = testingImport.default\n\n    if (!testingDefault) throw new Error(\"Testing config must export a default function\")\n    if (typeof testingDefault !== \"function\") throw new Error(\"Testing config default export isn't a function\")\n\n    const result = await testingDefault()\n\n    if (typeof result === \"function\") {\n      await result()\n    }\n  }\n\n  /**\n   * @param {string} filePath - File path.\n   * @returns {Promise<import(\"../database/migration/index.js\").default>} - Resolves with the require migration.\n   */\n  async requireMigration(filePath) {\n    const migrationImport = await import(toImportSpecifier(filePath))\n    const migrationImportDefault = migrationImport.default\n\n    if (!migrationImportDefault) throw new Error(\"Migration file must export a default migration class\")\n    if (typeof migrationImportDefault !== \"function\") throw new Error(\"Migration default export isn't a function (should be a class which is a function in JS)\")\n\n    return migrationImportDefault\n  }\n\n  async getBasePath() {\n    const __filename = fileURLToPath(import.meta.url)\n    const basePath = await fs.realpath(`${dirname(__filename)}/../..`)\n\n    return basePath\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {Record<string, import(\"../database/drivers/base.js\").default>} args.dbs - Dbs.\n   * @param {\"migration\" | \"schemaDump\"} [args.reason] - Why the structure write is being triggered.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async afterMigrations({dbs, reason = \"migration\"}) {\n    const configuration = this.getConfiguration()\n\n    if (!configuration.shouldWriteStructureSql({reason})) return\n\n    const dbDir = path.join(configuration.getDirectory(), \"db\")\n    const structureSqlByIdentifier = await this._structureSqlByIdentifier({dbs})\n\n    await fs.mkdir(dbDir, {recursive: true})\n\n    for (const identifier of Object.keys(structureSqlByIdentifier)) {\n      const structureSql = structureSqlByIdentifier[identifier]\n\n      if (!structureSql) continue\n\n      const filePath = path.join(dbDir, `structure-${identifier}.sql`)\n\n      await fs.writeFile(filePath, structureSql)\n    }\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {Record<string, import(\"../database/drivers/base.js\").default>} args.dbs - Dbs.\n   * @returns {Promise<Record<string, string>>} - Resolves with SQL string.\n   */\n  async _structureSqlByIdentifier({dbs}) {\n    const sqlByIdentifier = /** @type {Record<string, string>} */ ({})\n\n    for (const identifier of Object.keys(dbs)) {\n      const db = dbs[identifier]\n\n      if (typeof db.structureSql !== \"function\") continue\n\n      const structureSql = await db.structureSql()\n\n      if (structureSql) {\n        sqlByIdentifier[identifier] = structureSql\n      }\n    }\n\n    return sqlByIdentifier\n  }\n}\n"]}
673
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.js","sourceRoot":"","sources":["../../../src/environment-handlers/node.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport Base from \"./base.js\"\nimport CliCommandsDestroyMigration from \"./node/cli/commands/destroy/migration.js\"\nimport CliCommandsInit from \"./node/cli/commands/init.js\"\nimport CliCommandsGenerateBaseModels from \"./node/cli/commands/generate/base-models.js\"\nimport CliCommandsGenerateFrontendModels from \"./node/cli/commands/generate/frontend-models.js\"\nimport CliCommandsGenerateMigration from \"./node/cli/commands/generate/migration.js\"\nimport CliCommandsGenerateModel from \"./node/cli/commands/generate/model.js\"\nimport CliCommandsRoutes from \"./node/cli/commands/routes.js\"\nimport CliCommandsServer from \"./node/cli/commands/server.js\"\nimport CliCommandsTest from \"./node/cli/commands/test.js\"\nimport CliCommandsBackgroundJobsMain from \"./node/cli/commands/background-jobs-main.js\"\nimport CliCommandsBackgroundJobsWorker from \"./node/cli/commands/background-jobs-worker.js\"\nimport CliCommandsBackgroundJobsRunner from \"./node/cli/commands/background-jobs-runner.js\"\nimport CliCommandsBeacon from \"./node/cli/commands/beacon.js\"\nimport CliCommandsConsole from \"./node/cli/commands/console.js\"\nimport CliCommandsDbSchemaDump from \"./node/cli/commands/db/schema/dump.js\"\nimport CliCommandsDbSchemaLoad from \"./node/cli/commands/db/schema/load.js\"\nimport CliCommandsDbSeed from \"./node/cli/commands/db/seed.js\"\nimport CliCommandsRunner from \"./node/cli/commands/runner.js\"\nimport CliCommandsRunScript from \"./node/cli/commands/run-script.js\"\nimport frontendModelCommandRouteHook from \"../routes/hooks/frontend-model-command-route-hook.js\"\nimport {FRAMEWORK_SOURCE_DIRECTORY} from \"../utils/backtrace-cleaner-node.js\"\nimport {dirname} from \"path\"\nimport {fileURLToPath} from \"url\"\nimport fs from \"fs/promises\"\nimport * as inflection from \"inflection\"\nimport path from \"path\"\nimport {AsyncLocalStorage as NodeAsyncLocalStorage} from \"node:async_hooks\"\nimport toImportSpecifier from \"../utils/to-import-specifier.js\"\n\n/** @typedef {{ability?: import(\"../authorization/ability.js\").default, offsetMinutes: number, requestTiming?: import(\"../http-server/client/request-timing.js\").default, tenant?: unknown}} TimezoneStore */\n\n/**\n * @param {string} filePath - Input file path.\n * @param {string[]} allowedPathPrefixes - Allowed path prefixes.\n * @returns {boolean} - Whether input path is inside an allowed prefix.\n */\nfunction pathWithinAllowedPrefixes(filePath, allowedPathPrefixes) {\n  const resolvedPath = path.resolve(filePath)\n\n  return allowedPathPrefixes.some((allowedPrefix) => {\n    const resolvedPrefix = path.resolve(allowedPrefix)\n    const relativePath = path.relative(resolvedPrefix, resolvedPath)\n\n    if (!relativePath) return true\n    if (relativePath.startsWith(\"..\")) return false\n    if (path.isAbsolute(relativePath)) return false\n\n    return true\n  })\n}\n\nexport default class VelociousEnvironmentHandlerNode extends Base{\n  /** @type {import(\"node:async_hooks\").AsyncLocalStorage<TimezoneStore> | undefined} */\n  _timezoneAsyncLocalStorage = NodeAsyncLocalStorage ? new NodeAsyncLocalStorage() : undefined\n\n  /** @type {import(\"./base.js\").CommandFileObjectType[] | undefined} */\n  _findCommandsResult = undefined\n\n  /**\n   * @returns {string | undefined} - Velocious source directory used to filter framework stack frames.\n   */\n  getFrameworkSourceDirectory() {\n    return FRAMEWORK_SOURCE_DIRECTORY\n  }\n\n  /**\n   * Auto-discovers resource classes from src/resources/ in each backend project.\n   * @param {import(\"../configuration.js\").default} configuration - Configuration instance.\n   * @returns {Promise<void>}\n   */\n  async autoDiscoverResources(configuration) {\n    const {frontendModelResourceDefinitionIsClass} = await import(\"../frontend-models/resource-definition.js\")\n    const backendProjects = configuration.getBackendProjects()\n\n    for (const backendProject of backendProjects) {\n      if (backendProject.frontendModels) continue\n\n      const resourcesDir = path.join(backendProject.path, \"src\", \"resources\")\n      let files\n\n      try {\n        files = await fs.readdir(resourcesDir)\n      } catch {\n        continue\n      }\n\n      /** @type {Record<string, any>} */\n      const discovered = {}\n\n      for (const file of files) {\n        if (!file.endsWith(\".js\") && !file.endsWith(\".mjs\")) continue\n        if (file.startsWith(\"frontend-model-resources\")) continue\n\n        const filePath = path.join(resourcesDir, file)\n        const imported = await import(filePath)\n        const ResourceClass = imported.default\n\n        if (!frontendModelResourceDefinitionIsClass(ResourceClass)) continue\n\n        const baseName = file.replace(/\\.(js|mjs)$/, \"\")\n        const modelName = baseName.replace(/-resource$/, \"\")\n          .split(\"-\")\n          .map((/** @type {string} */ part) => part.charAt(0).toUpperCase() + part.slice(1))\n          .join(\"\")\n\n        discovered[modelName] = ResourceClass\n      }\n\n      if (Object.keys(discovered).length > 0) {\n        backendProject.frontendModels = discovered\n      }\n    }\n  }\n\n  /**\n   * @param {import(\"../configuration.js\").default} newConfiguration - New configuration.\n   * @returns {void} - No return value.\n   */\n  setConfiguration(newConfiguration) {\n    super.setConfiguration(newConfiguration)\n\n    if (!newConfiguration.getRouteResolverHooks().includes(frontendModelCommandRouteHook)) {\n      newConfiguration.addRouteResolverHook(frontendModelCommandRouteHook)\n    }\n  }\n\n  /**\n   * @param {string} filePath - File path.\n   * @returns {Promise<Buffer>} - File bytes.\n   */\n  async readAttachmentInputFile(filePath) {\n    return await fs.readFile(filePath)\n  }\n\n  /**\n   * @param {object} args - Args.\n   * @param {string[]} args.allowedPathPrefixes - Allowed path prefixes.\n   * @param {string} args.inputPath - Input path.\n   * @returns {Promise<{buffer: Buffer, filePath: string}>} - Resolved path and bytes.\n   */\n  async resolveAttachmentInputPath({allowedPathPrefixes, inputPath}) {\n    const filePath = path.resolve(inputPath)\n    const prefixes = Array.isArray(allowedPathPrefixes)\n      ? allowedPathPrefixes.filter((entry) => typeof entry === \"string\" && entry.length > 0)\n      : []\n\n    if (prefixes.length > 0 && !pathWithinAllowedPrefixes(filePath, prefixes)) {\n      throw new Error(\"Attachment path is outside allowed directories\")\n    }\n\n    const buffer = await this.readAttachmentInputFile(filePath)\n\n    return {buffer, filePath}\n  }\n\n  /**\n   * @returns {Promise<Array<import(\"./base.js\").CommandFileObjectType>>} - Resolves with the commands.\n   */\n  async findCommands() {\n    this._findCommandsResult ||= await this._actualFindCommands()\n\n    if (!this._findCommandsResult) throw new Error(\"Could not get commands\")\n\n    return this._findCommandsResult\n  }\n\n  /**\n   * @param {number} offsetMinutes - Offset in minutes (Date#getTimezoneOffset).\n   * @param {() => Promise<any>} callback - Callback to run.\n   * @returns {Promise<any>} - Result of the callback.\n   */\n  async runWithTimezoneOffset(offsetMinutes, callback) {\n    if (!this._timezoneAsyncLocalStorage) {\n      return await callback()\n    }\n\n    const existingStore = this._timezoneAsyncLocalStorage.getStore()\n\n    return await this._timezoneAsyncLocalStorage.run({\n      ability: existingStore?.ability,\n      offsetMinutes,\n      requestTiming: existingStore?.requestTiming,\n      tenant: existingStore?.tenant\n    }, callback)\n  }\n\n  /**\n   * @param {number} offsetMinutes - Offset in minutes (Date#getTimezoneOffset).\n   * @returns {void} - No return value.\n   */\n  setTimezoneOffset(offsetMinutes) {\n    if (!this._timezoneAsyncLocalStorage) return\n\n    const store = this._timezoneAsyncLocalStorage.getStore()\n\n    if (store) {\n      store.offsetMinutes = offsetMinutes\n    } else {\n      const existingStore = this._timezoneAsyncLocalStorage.getStore()\n\n      this._timezoneAsyncLocalStorage.enterWith({\n        ability: existingStore?.ability,\n        offsetMinutes,\n        requestTiming: existingStore?.requestTiming,\n        tenant: existingStore?.tenant\n      })\n    }\n  }\n\n  /**\n   * @param {import(\"../configuration.js\").default | undefined} configuration - Configuration instance.\n   * @returns {number} - Offset in minutes.\n   */\n  getTimezoneOffsetMinutes(configuration) {\n    if (this._timezoneAsyncLocalStorage) {\n      const store = this._timezoneAsyncLocalStorage.getStore()\n\n      if (store && typeof store.offsetMinutes === \"number\") {\n        return store.offsetMinutes\n      }\n    }\n\n    return super.getTimezoneOffsetMinutes(configuration)\n  }\n\n  /**\n   * @param {import(\"../authorization/ability.js\").default | undefined} ability - Ability to set for callback scope.\n   * @param {() => Promise<any>} callback - Callback.\n   * @returns {Promise<any>} - Callback result.\n   */\n  async runWithAbility(ability, callback) {\n    if (!this._timezoneAsyncLocalStorage) {\n      return await super.runWithAbility(ability, callback)\n    }\n\n    const existingStore = this._timezoneAsyncLocalStorage.getStore()\n\n    return await this._timezoneAsyncLocalStorage.run({\n      ability,\n      offsetMinutes: existingStore?.offsetMinutes ?? this.getTimezoneOffsetMinutes(this.getConfiguration()),\n      requestTiming: existingStore?.requestTiming,\n      tenant: existingStore?.tenant\n    }, callback)\n  }\n\n  /**\n   * @param {import(\"../authorization/ability.js\").default | undefined} ability - Ability to set.\n   * @returns {void} - No return value.\n   */\n  setCurrentAbility(ability) {\n    if (!this._timezoneAsyncLocalStorage) {\n      super.setCurrentAbility(ability)\n      return\n    }\n\n    const existingStore = this._timezoneAsyncLocalStorage.getStore()\n\n    if (existingStore) {\n      existingStore.ability = ability\n    } else {\n      this._timezoneAsyncLocalStorage.enterWith({\n        ability,\n        offsetMinutes: this.getTimezoneOffsetMinutes(this.getConfiguration()),\n        requestTiming: undefined,\n        tenant: undefined\n      })\n    }\n  }\n\n  /**\n   * @returns {import(\"../authorization/ability.js\").default | undefined} - Current ability.\n   */\n  getCurrentAbility() {\n    if (!this._timezoneAsyncLocalStorage) {\n      return super.getCurrentAbility()\n    }\n\n    return this._timezoneAsyncLocalStorage.getStore()?.ability\n  }\n\n  /**\n   * @param {import(\"../http-server/client/request-timing.js\").default | undefined} requestTiming - Request timing collector.\n   * @param {() => Promise<any>} callback - Callback.\n   * @returns {Promise<any>} - Callback result.\n   */\n  async runWithRequestTiming(requestTiming, callback) {\n    if (!this._timezoneAsyncLocalStorage) {\n      return await super.runWithRequestTiming(requestTiming, callback)\n    }\n\n    const existingStore = this._timezoneAsyncLocalStorage.getStore()\n\n    return await this._timezoneAsyncLocalStorage.run({\n      ability: existingStore?.ability,\n      offsetMinutes: existingStore?.offsetMinutes ?? this.getTimezoneOffsetMinutes(this.getConfiguration()),\n      requestTiming,\n      tenant: existingStore?.tenant\n    }, callback)\n  }\n\n  /**\n   * @returns {import(\"../http-server/client/request-timing.js\").default | undefined} - Current request timing collector.\n   */\n  getCurrentRequestTiming() {\n    if (!this._timezoneAsyncLocalStorage) {\n      return super.getCurrentRequestTiming()\n    }\n\n    return this._timezoneAsyncLocalStorage.getStore()?.requestTiming\n  }\n\n  /**\n   * @param {unknown} tenant - Tenant to set for callback scope.\n   * @param {() => Promise<any>} callback - Callback.\n   * @returns {Promise<any>} - Callback result.\n   */\n  async runWithTenant(tenant, callback) {\n    if (!this._timezoneAsyncLocalStorage) {\n      return await super.runWithTenant(tenant, callback)\n    }\n\n    const existingStore = this._timezoneAsyncLocalStorage.getStore()\n\n    return await this._timezoneAsyncLocalStorage.run({\n      ability: existingStore?.ability,\n      offsetMinutes: existingStore?.offsetMinutes ?? this.getTimezoneOffsetMinutes(this.getConfiguration()),\n      requestTiming: existingStore?.requestTiming,\n      tenant\n    }, callback)\n  }\n\n  /**\n   * @param {unknown} tenant - Tenant to set.\n   * @returns {void} - No return value.\n   */\n  setCurrentTenant(tenant) {\n    if (!this._timezoneAsyncLocalStorage) {\n      super.setCurrentTenant(tenant)\n      return\n    }\n\n    const existingStore = this._timezoneAsyncLocalStorage.getStore()\n\n    if (existingStore) {\n      existingStore.tenant = tenant\n    } else {\n      this._timezoneAsyncLocalStorage.enterWith({\n        ability: undefined,\n        offsetMinutes: this.getTimezoneOffsetMinutes(this.getConfiguration()),\n        requestTiming: undefined,\n        tenant\n      })\n    }\n  }\n\n  /**\n   * @returns {unknown} - Current tenant.\n   */\n  getCurrentTenant() {\n    if (!this._timezoneAsyncLocalStorage) {\n      return super.getCurrentTenant()\n    }\n\n    return this._timezoneAsyncLocalStorage.getStore()?.tenant\n  }\n\n  /**\n   * @returns {Promise<Array<import(\"./base.js\").CommandFileObjectType>>} - Resolves with discovered command files.\n   */\n  async _actualFindCommands() {\n    const basePath = await this.getBasePath()\n    const commandFiles = fs.glob(`${basePath}/src/cli/commands/**/*.js`)\n    const commands = []\n\n    for await (const aFilePath of commandFiles) {\n      const commandName = this.commandNameFromFilePath(aFilePath)\n\n      commands.push({name: commandName, file: aFilePath})\n    }\n\n    return commands\n  }\n\n  /**\n   * @param {string} filePath - Full command file path.\n   * @returns {string} - Parsed command name.\n   */\n  commandNameFromFilePath(filePath) {\n    const aFilePathParts = filePath.split(/[\\\\/]/)\n    const commandPathLocation = aFilePathParts.indexOf(\"commands\")\n\n    if (commandPathLocation === -1) {\n      throw new Error(`Could not parse command file path: ${filePath}`)\n    }\n\n    const commandParts = aFilePathParts.slice(commandPathLocation + 1)\n    const lastPart = commandParts[commandParts.length - 1]\n    let name, paths\n\n    if (lastPart == \"index.js\") {\n      name = commandParts[commandParts.length - 2]\n      paths = commandParts.slice(0, -2)\n    } else {\n      name = lastPart.replace(\".js\", \"\")\n      paths = commandParts.slice(0, -1)\n    }\n\n    return `${paths.join(\":\")}${paths.length > 0 ? \":\" : \"\"}${name}`\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsInit(command) {\n    return await this.forwardCommand(command, CliCommandsInit)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsMigrationGenerate(command) {\n    return await this.forwardCommand(command, CliCommandsGenerateMigration)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsMigrationDestroy(command) {\n    return await this.forwardCommand(command, CliCommandsDestroyMigration)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsGenerateBaseModels(command) {\n    return await this.forwardCommand(command, CliCommandsGenerateBaseModels)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsGenerateFrontendModels(command) {\n    return await this.forwardCommand(command, CliCommandsGenerateFrontendModels)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsGenerateModel(command) {\n    return await this.forwardCommand(command, CliCommandsGenerateModel)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsRoutes(command) {\n    return await this.forwardCommand(command, CliCommandsRoutes)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsConsole(command) {\n    return await this.forwardCommand(command, CliCommandsConsole)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsServer(command) {\n    return await this.forwardCommand(command, CliCommandsServer)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsTest(command) {\n    return await this.forwardCommand(command, CliCommandsTest)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsBackgroundJobsMain(command) {\n    return await this.forwardCommand(command, CliCommandsBackgroundJobsMain)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsBackgroundJobsWorker(command) {\n    return await this.forwardCommand(command, CliCommandsBackgroundJobsWorker)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsBackgroundJobsRunner(command) {\n    return await this.forwardCommand(command, CliCommandsBackgroundJobsRunner)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsBeacon(command) {\n    return await this.forwardCommand(command, CliCommandsBeacon)\n  }\n\n  /** @returns {Promise<typeof import(\"../beacon/client.js\").default>} - Beacon client class. */\n  async loadBeaconClient() {\n    const {default: BeaconClient} = await import(\"../beacon/client.js\")\n\n    return BeaconClient\n  }\n\n  /** @returns {Promise<typeof import(\"../beacon/in-process-client.js\").default>} - In-process client class. */\n  async loadInProcessBeaconClient() {\n    const {default: InProcessBeaconClient} = await import(\"../beacon/in-process-client.js\")\n\n    return InProcessBeaconClient\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsDbSchemaDump(command) {\n    return await this.forwardCommand(command, CliCommandsDbSchemaDump)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsDbSchemaLoad(command) {\n    return await this.forwardCommand(command, CliCommandsDbSchemaLoad)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsDbSeed(command) {\n    return await this.forwardCommand(command, CliCommandsDbSeed)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsRunner(command) {\n    return await this.forwardCommand(command, CliCommandsRunner)\n  }\n\n  /**\n   * @param {import(\"../cli/base-command.js\").default} command - Command.\n   * @returns {Promise<unknown>} - Resolves with the command result.\n   */\n  async cliCommandsRunScript(command) {\n    return await this.forwardCommand(command, CliCommandsRunScript)\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {string[]} args.commandParts - Command parts.\n   * @returns {Promise<typeof import (\"../cli/base-command.js\").default>} - Resolves with the require command.\n   */\n  async requireCommand({commandParts}) {\n    const commands = await this.findCommands()\n    const commandName = commandParts.join(\":\")\n    const command = commands.find((aCommand) => aCommand.name === commandName)\n\n    if (!command) {\n      const possibleCommands = commands.map(aCommand => aCommand.name)\n\n      throw new Error(`Unknown command: ${commandParts.join(\":\")} which should have been one of: ${possibleCommands.sort().join(\", \")}`)\n    }\n\n    const commandClassImport = await import(toImportSpecifier(command.file))\n    const CommandClass = commandClassImport.default\n\n    return CommandClass\n  }\n\n  /**\n   * @returns {Promise<Array<import(\"./base.js\").MigrationObjectType>>} - Resolves with the migrations.\n   */\n  async findMigrations() {\n    const migrationsPath = `${this.getConfiguration().getDirectory()}/src/database/migrations`\n    const glob = await fs.glob(`${migrationsPath}/**/*.js`)\n    let files = []\n\n    for await (const fullPath of glob) {\n      const file = await path.basename(fullPath)\n\n      const match = file.match(/^(\\d{14})-(.+)\\.js$/)\n\n      if (!match) continue\n\n      const date = parseInt(match[1])\n      const migrationName = match[2]\n      const migrationClassName = inflection.camelize(migrationName.replaceAll(\"-\", \"_\"))\n\n      files.push({\n        file,\n        fullPath: `${migrationsPath}/${file}`,\n        date,\n        migrationClassName\n      })\n    }\n\n    files = files.sort((migration1, migration2) => migration1.date - migration2.date)\n\n    return files\n  }\n\n  /**\n   * @returns {Promise<import(\"../routes/index.js\").default>} - Resolves with the import application routes.\n   */\n  async importApplicationRoutes() {\n    const routesImport = await import(toImportSpecifier(`${this.getConfiguration().getDirectory()}/src/config/routes.js`))\n\n    return routesImport.default\n  }\n\n  /**\n   * @returns {Promise<string>} - Resolves with the velocious path.\n   */\n  async getVelociousPath() {\n    if (!this._velociousPath) {\n      const __filename = fileURLToPath(import.meta.url)\n      const __dirname = dirname(__filename)\n\n      this._velociousPath = await fs.realpath(`${__dirname}/../..`)\n    }\n\n    return this._velociousPath\n  }\n\n  /**\n   * @param {string[]} testFiles - Test files.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async importTestFiles(testFiles) {\n    for (const testFile of testFiles) {\n      await import(toImportSpecifier(testFile))\n    }\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {import(\"../configuration.js\").default} args.configuration - Configuration instance.\n   * @returns {string} - The default log directory.\n   */\n  getDefaultLogDirectory({configuration}) {\n    return path.join(configuration.getDirectory(), \"log\")\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {import(\"../configuration.js\").default} args.configuration - Configuration instance.\n   * @param {string | undefined} args.directory - Directory path.\n   * @param {string} args.environment - Environment.\n   * @returns {string | undefined} - The log file path.\n   */\n  getLogFilePath({configuration, directory, environment}) {\n    const actualDirectory = directory || configuration?.getDirectory?.()\n\n    if (!actualDirectory) return undefined\n\n    return path.join(actualDirectory, `${environment}.log`)\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {string} args.filePath - File path.\n   * @param {string} args.message - Message text.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async writeLogToFile({filePath, message}) {\n    await fs.mkdir(path.dirname(filePath), {recursive: true})\n    await fs.appendFile(filePath, `${message}\\n`, \"utf8\")\n  }\n\n  async importTestingConfigPath() {\n    const testingConfigPath = this.getConfiguration().getTesting()\n\n    if (!testingConfigPath) return\n\n    const testingImport = await import(toImportSpecifier(testingConfigPath))\n    const testingDefault = testingImport.default\n\n    if (!testingDefault) throw new Error(\"Testing config must export a default function\")\n    if (typeof testingDefault !== \"function\") throw new Error(\"Testing config default export isn't a function\")\n\n    const result = await testingDefault()\n\n    if (typeof result === \"function\") {\n      await result()\n    }\n  }\n\n  /**\n   * @param {string} filePath - File path.\n   * @returns {Promise<import(\"../database/migration/index.js\").default>} - Resolves with the require migration.\n   */\n  async requireMigration(filePath) {\n    const migrationImport = await import(toImportSpecifier(filePath))\n    const migrationImportDefault = migrationImport.default\n\n    if (!migrationImportDefault) throw new Error(\"Migration file must export a default migration class\")\n    if (typeof migrationImportDefault !== \"function\") throw new Error(\"Migration default export isn't a function (should be a class which is a function in JS)\")\n\n    return migrationImportDefault\n  }\n\n  async getBasePath() {\n    const __filename = fileURLToPath(import.meta.url)\n    const basePath = await fs.realpath(`${dirname(__filename)}/../..`)\n\n    return basePath\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {Record<string, import(\"../database/drivers/base.js\").default>} args.dbs - Dbs.\n   * @param {\"migration\" | \"schemaDump\"} [args.reason] - Why the structure write is being triggered.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async afterMigrations({dbs, reason = \"migration\"}) {\n    const configuration = this.getConfiguration()\n\n    if (!configuration.shouldWriteStructureSql({reason})) return\n\n    const dbDir = path.join(configuration.getDirectory(), \"db\")\n    const structureSqlByIdentifier = await this._structureSqlByIdentifier({dbs})\n\n    await fs.mkdir(dbDir, {recursive: true})\n\n    for (const identifier of Object.keys(structureSqlByIdentifier)) {\n      const structureSql = structureSqlByIdentifier[identifier]\n\n      if (!structureSql) continue\n\n      const filePath = path.join(dbDir, `structure-${identifier}.sql`)\n\n      await fs.writeFile(filePath, structureSql)\n    }\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {Record<string, import(\"../database/drivers/base.js\").default>} args.dbs - Dbs.\n   * @returns {Promise<Record<string, string>>} - Resolves with SQL string.\n   */\n  async _structureSqlByIdentifier({dbs}) {\n    const sqlByIdentifier = /** @type {Record<string, string>} */ ({})\n\n    for (const identifier of Object.keys(dbs)) {\n      const db = dbs[identifier]\n\n      if (typeof db.structureSql !== \"function\") continue\n\n      const structureSql = await db.structureSql()\n\n      if (structureSql) {\n        sqlByIdentifier[identifier] = structureSql\n      }\n    }\n\n    return sqlByIdentifier\n  }\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  // @ts-check
2
- import BacktraceCleaner from "../../utils/backtrace-cleaner.js";
2
+ import BacktraceCleaner from "../../utils/backtrace-cleaner-node.js";
3
3
  import ensureError from "../../utils/ensure-error.js";
4
4
  import EventEmitter from "../../utils/event-emitter.js";
5
5
  import Logger from "../../logger.js";
@@ -261,4 +261,4 @@ export default class VelociousHttpServerClientRequestRunner {
261
261
  await logger[requestTiming.completedLogMethod](completedMessage);
262
262
  }
263
263
  }
264
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"request-runner.js","sourceRoot":"","sources":["../../../../src/http-server/client/request-runner.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport BacktraceCleaner from \"../../utils/backtrace-cleaner.js\"\nimport ensureError from \"../../utils/ensure-error.js\"\nimport EventEmitter from \"../../utils/event-emitter.js\"\nimport Logger from \"../../logger.js\"\nimport RequestTiming from \"./request-timing.js\"\nimport Response from \"./response.js\"\nimport RoutesResolver from \"../../routes/resolver.js\"\n\n/**\n * @param {string | undefined} line - Potential header line.\n * @returns {boolean} - Whether the line is a stack frame.\n */\nfunction stackFrameLine(line) {\n  if (!line) return false\n\n  return /^at\\s+/u.test(line.trim())\n}\n\n/**\n * @param {Error} error - Error to format for logging.\n * @param {string | undefined} cleanedStackWithHeader - Cleaned stack with header line.\n * @returns {string} - Error summary line with type information.\n */\nfunction requestErrorSummary(error, cleanedStackWithHeader) {\n  const stackHeader = cleanedStackWithHeader?.split(\"\\n\")[0]?.trim()\n\n  if (stackHeader && !stackFrameLine(stackHeader)) return stackHeader\n\n  const errorCode = typeof /** @type {any} */ (error).code === \"string\"\n    ? /** @type {any} */ (error).code\n    : undefined\n  const errorMessage = error.message || String(error)\n\n  if (errorCode) return `${error.name} [${errorCode}]: ${errorMessage}`\n\n  return `${error.name}: ${errorMessage}`\n}\n\n/**\n * @param {Error} error - Error to format for logging.\n * @returns {{\n *   errorSummary: string,\n *   cleanedBacktrace: string | undefined,\n * }} - Log details.\n */\nfunction requestErrorLogDetails(error) {\n  const cleanedStackWithHeader = BacktraceCleaner.getCleanedStack(error)\n  const errorSummary = requestErrorSummary(error, cleanedStackWithHeader)\n  const cleanedBacktrace = BacktraceCleaner.getCleanedStack(error, {includeErrorHeader: false}) || cleanedStackWithHeader\n\n  return {errorSummary, cleanedBacktrace}\n}\n\n/**\n * @param {{\n *   errorSummary: string,\n *   cleanedBacktrace: string | undefined,\n * }} logDetails - Log details.\n * @returns {string} - Single request error log message.\n */\nfunction requestErrorLogMessage(logDetails) {\n  if (!logDetails.cleanedBacktrace) {\n    return `Error while running request: ${logDetails.errorSummary}`\n  }\n\n  return `Error while running request: ${logDetails.errorSummary}\\nCleaned backtrace:\\n${logDetails.cleanedBacktrace}`\n}\n\n/**\n * @param {Response} response - Response object.\n * @returns {string} - Response body type for logging.\n */\nfunction responseBodyTypeForLog(response) {\n  if (response.getFilePath()) return \"file\"\n\n  try {\n    return typeof response.getBody()\n  } catch {\n    return \"unset\"\n  }\n}\n\n/**\n * @param {number} value - Milliseconds.\n * @returns {string} - Formatted milliseconds with one decimal place.\n */\nfunction formatBucketMs(value) {\n  return `${value.toFixed(1)}ms`\n}\n\n/**\n * @param {number} count - Query count.\n * @returns {string} - Query count label.\n */\nfunction queryCountLabel(count) {\n  return `${count} ${count === 1 ? \"query\" : \"queries\"}`\n}\n\nexport default class VelociousHttpServerClientRequestRunner {\n  events = new EventEmitter()\n\n  /**\n   * @param {object} args - Options object.\n   * @param {import(\"../../configuration.js\").default} args.configuration - Configuration instance.\n   * @param {import(\"./request.js\").default | import(\"./websocket-request.js\").default} args.request - Request object.\n   */\n  constructor({configuration, request}) {\n    if (!configuration) throw new Error(\"No configuration given\")\n    if (!request) throw new Error(\"No request given\")\n\n    this.logger = new Logger(this)\n    this.configuration = configuration\n    this.request = request\n    this.response = new Response({configuration})\n    this.completedRequestLogged = false\n    this.requestTiming = new RequestTiming()\n    this.state = \"running\"\n  }\n\n  getRequest() { return this.request }\n  getState() { return this.state }\n\n  async run() {\n    this.requestTiming.startedAtMs = Date.now()\n\n    return await this.configuration.runWithRequestTiming(this.requestTiming, async () => {\n      await this._run()\n    })\n  }\n\n  async _run() {\n    const {configuration, request, response} = this\n\n    if (!request) throw new Error(\"No request?\")\n\n    try {\n      await this.logger.debug(() => [\"Run request lifecycle\", {\n        httpMethod: request.httpMethod(),\n        httpVersion: request.httpVersion(),\n        origin: request.origin(),\n        path: request.path(),\n        remoteAddress: request.remoteAddress()\n      }])\n      // Before we checked if the sec-fetch-mode was \"cors\", but it seems the sec-fetch-mode isn't always present\n      await this.logger.debug(() => [\"Run CORS\", {httpMethod: request.httpMethod(), secFetchMode: request.header(\"sec-fetch-mode\")}])\n\n      const cors = configuration.getCors()\n\n      if (cors) {\n        await cors({request, response})\n        await this.logger.debug(() => [\"CORS handler done\", {\n          httpMethod: request.httpMethod(),\n          path: request.path(),\n          responseStatusCode: response.getStatusCode()\n        }])\n      }\n\n      if (request.httpMethod() == \"OPTIONS\" && request.header(\"sec-fetch-mode\") == \"cors\") {\n        response.setStatus(200)\n        response.setBody(\"\")\n        await this.logger.debug(() => [\"Handled preflight OPTIONS request\", {\n          path: request.path(),\n          responseStatusCode: response.getStatusCode()\n        }])\n      } else {\n        await this.logger.debug(\"Run request\")\n        const routesResolver = new RoutesResolver({configuration, request, response})\n        const startTimeMs = Date.now()\n        /** @type {ReturnType<typeof setTimeout> | undefined} */\n        let timeoutId\n        /** @type {((error: Error) => void) | undefined} */\n        let timeoutReject\n        let timedOut = false\n\n        const setRequestTimeoutSeconds = (/** @type {number | undefined} */ timeoutSeconds) => {\n          if (timeoutId) {\n            clearTimeout(timeoutId)\n            timeoutId = undefined\n          }\n\n          if (typeof timeoutSeconds !== \"number\" || !Number.isFinite(timeoutSeconds) || timeoutSeconds <= 0) {\n            return\n          }\n\n          const timeoutMs = timeoutSeconds * 1000\n          const elapsedMs = Date.now() - startTimeMs\n          const remainingMs = timeoutMs - elapsedMs\n\n          if (remainingMs <= 0) {\n            timeoutReject?.(new Error(`Request timed out after ${timeoutSeconds}s`))\n            return\n          }\n\n          timeoutId = setTimeout(() => {\n            timeoutReject?.(new Error(`Request timed out after ${timeoutSeconds}s`))\n          }, remainingMs)\n        }\n\n        const timeoutPromise = new Promise((_, reject) => {\n          timeoutReject = (error) => {\n            timedOut = true\n            reject(error)\n          }\n        })\n\n        response.setRequestTimeoutMsChangeHandler((timeoutSeconds) => {\n          setRequestTimeoutSeconds(timeoutSeconds)\n        })\n\n        setRequestTimeoutSeconds(configuration.getRequestTimeoutMs?.())\n\n        let resolvePromise\n\n        try {\n          resolvePromise = routesResolver.resolve()\n          // Keep Promise.race here to allow dynamic timeout updates.\n          await Promise.race([resolvePromise, timeoutPromise])\n          await this.logger.debug(() => [\"Routes resolver done\", {\n            httpMethod: request.httpMethod(),\n            path: request.path(),\n            responseStatusCode: response.getStatusCode(),\n            hasFilePath: Boolean(response.getFilePath()),\n            bodyType: responseBodyTypeForLog(response)\n          }])\n        } catch (error) {\n          if (timedOut && resolvePromise) {\n            void resolvePromise.catch((resolveError) => {\n              this.logger.warn(() => [\"Request finished after timeout\", resolveError])\n            })\n          }\n          throw error\n        } finally {\n          if (timeoutId) clearTimeout(timeoutId)\n        }\n      }\n    } catch (e) {\n      const error = ensureError(e)\n      const errorWithContext = /** @type {{velociousContext?: object}} */ (error)\n      const errorContext = errorWithContext.velociousContext || {stage: \"request-runner\"}\n      const logDetails = requestErrorLogDetails(error)\n\n      await this.logger.error(() => requestErrorLogMessage(logDetails))\n\n      const errorPayload = {\n        context: errorContext,\n        error,\n        request,\n        response\n      }\n\n      configuration.getErrorEvents().emit(\"framework-error\", errorPayload)\n      configuration.getErrorEvents().emit(\"all-error\", {\n        ...errorPayload,\n        errorType: \"framework-error\"\n      })\n\n      response.setStatus(500)\n      response.setErrorBody(error)\n    }\n\n    await this.logger.debug(() => [\"Request runner done\", {\n      httpMethod: request.httpMethod(),\n      path: request.path(),\n      responseStatusCode: response.getStatusCode()\n    }])\n    this.state = \"done\"\n    this.events.emit(\"done\", this)\n  }\n\n  /** @returns {Promise<void>} - Logs the completed request line after the response has been served. */\n  async logCompletedRequest() {\n    if (this.completedRequestLogged) return\n\n    this.completedRequestLogged = true\n\n    const requestTiming = this.requestTiming\n\n    requestTiming.markResponseServed()\n\n    if (!requestTiming.completedLogSubject || !requestTiming.completedLogMethod) return\n\n    const logger = new Logger(requestTiming.completedLogSubject, {configuration: this.configuration})\n    const summary = requestTiming.summary()\n    const response = this.response\n    const completedMessage = [\n      `Completed ${response.getStatusCode()} ${response.getStatusMessage()} in ${Math.round(summary.totalMs)}ms (`,\n      `Controller: ${formatBucketMs(summary.controllerMs)}`,\n      ` | Views: ${formatBucketMs(summary.viewsMs)}`,\n      ` | DB: ${formatBucketMs(summary.dbMs)} (${queryCountLabel(summary.dbQueryCount)})`,\n      ` | Velocious: ${formatBucketMs(summary.velociousMs)}`,\n      `)`\n    ].join(\"\")\n\n    await logger[requestTiming.completedLogMethod](completedMessage)\n  }\n}\n"]}
264
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"request-runner.js","sourceRoot":"","sources":["../../../../src/http-server/client/request-runner.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport BacktraceCleaner from \"../../utils/backtrace-cleaner-node.js\"\nimport ensureError from \"../../utils/ensure-error.js\"\nimport EventEmitter from \"../../utils/event-emitter.js\"\nimport Logger from \"../../logger.js\"\nimport RequestTiming from \"./request-timing.js\"\nimport Response from \"./response.js\"\nimport RoutesResolver from \"../../routes/resolver.js\"\n\n/**\n * @param {string | undefined} line - Potential header line.\n * @returns {boolean} - Whether the line is a stack frame.\n */\nfunction stackFrameLine(line) {\n  if (!line) return false\n\n  return /^at\\s+/u.test(line.trim())\n}\n\n/**\n * @param {Error} error - Error to format for logging.\n * @param {string | undefined} cleanedStackWithHeader - Cleaned stack with header line.\n * @returns {string} - Error summary line with type information.\n */\nfunction requestErrorSummary(error, cleanedStackWithHeader) {\n  const stackHeader = cleanedStackWithHeader?.split(\"\\n\")[0]?.trim()\n\n  if (stackHeader && !stackFrameLine(stackHeader)) return stackHeader\n\n  const errorCode = typeof /** @type {any} */ (error).code === \"string\"\n    ? /** @type {any} */ (error).code\n    : undefined\n  const errorMessage = error.message || String(error)\n\n  if (errorCode) return `${error.name} [${errorCode}]: ${errorMessage}`\n\n  return `${error.name}: ${errorMessage}`\n}\n\n/**\n * @param {Error} error - Error to format for logging.\n * @returns {{\n *   errorSummary: string,\n *   cleanedBacktrace: string | undefined,\n * }} - Log details.\n */\nfunction requestErrorLogDetails(error) {\n  const cleanedStackWithHeader = BacktraceCleaner.getCleanedStack(error)\n  const errorSummary = requestErrorSummary(error, cleanedStackWithHeader)\n  const cleanedBacktrace = BacktraceCleaner.getCleanedStack(error, {includeErrorHeader: false}) || cleanedStackWithHeader\n\n  return {errorSummary, cleanedBacktrace}\n}\n\n/**\n * @param {{\n *   errorSummary: string,\n *   cleanedBacktrace: string | undefined,\n * }} logDetails - Log details.\n * @returns {string} - Single request error log message.\n */\nfunction requestErrorLogMessage(logDetails) {\n  if (!logDetails.cleanedBacktrace) {\n    return `Error while running request: ${logDetails.errorSummary}`\n  }\n\n  return `Error while running request: ${logDetails.errorSummary}\\nCleaned backtrace:\\n${logDetails.cleanedBacktrace}`\n}\n\n/**\n * @param {Response} response - Response object.\n * @returns {string} - Response body type for logging.\n */\nfunction responseBodyTypeForLog(response) {\n  if (response.getFilePath()) return \"file\"\n\n  try {\n    return typeof response.getBody()\n  } catch {\n    return \"unset\"\n  }\n}\n\n/**\n * @param {number} value - Milliseconds.\n * @returns {string} - Formatted milliseconds with one decimal place.\n */\nfunction formatBucketMs(value) {\n  return `${value.toFixed(1)}ms`\n}\n\n/**\n * @param {number} count - Query count.\n * @returns {string} - Query count label.\n */\nfunction queryCountLabel(count) {\n  return `${count} ${count === 1 ? \"query\" : \"queries\"}`\n}\n\nexport default class VelociousHttpServerClientRequestRunner {\n  events = new EventEmitter()\n\n  /**\n   * @param {object} args - Options object.\n   * @param {import(\"../../configuration.js\").default} args.configuration - Configuration instance.\n   * @param {import(\"./request.js\").default | import(\"./websocket-request.js\").default} args.request - Request object.\n   */\n  constructor({configuration, request}) {\n    if (!configuration) throw new Error(\"No configuration given\")\n    if (!request) throw new Error(\"No request given\")\n\n    this.logger = new Logger(this)\n    this.configuration = configuration\n    this.request = request\n    this.response = new Response({configuration})\n    this.completedRequestLogged = false\n    this.requestTiming = new RequestTiming()\n    this.state = \"running\"\n  }\n\n  getRequest() { return this.request }\n  getState() { return this.state }\n\n  async run() {\n    this.requestTiming.startedAtMs = Date.now()\n\n    return await this.configuration.runWithRequestTiming(this.requestTiming, async () => {\n      await this._run()\n    })\n  }\n\n  async _run() {\n    const {configuration, request, response} = this\n\n    if (!request) throw new Error(\"No request?\")\n\n    try {\n      await this.logger.debug(() => [\"Run request lifecycle\", {\n        httpMethod: request.httpMethod(),\n        httpVersion: request.httpVersion(),\n        origin: request.origin(),\n        path: request.path(),\n        remoteAddress: request.remoteAddress()\n      }])\n      // Before we checked if the sec-fetch-mode was \"cors\", but it seems the sec-fetch-mode isn't always present\n      await this.logger.debug(() => [\"Run CORS\", {httpMethod: request.httpMethod(), secFetchMode: request.header(\"sec-fetch-mode\")}])\n\n      const cors = configuration.getCors()\n\n      if (cors) {\n        await cors({request, response})\n        await this.logger.debug(() => [\"CORS handler done\", {\n          httpMethod: request.httpMethod(),\n          path: request.path(),\n          responseStatusCode: response.getStatusCode()\n        }])\n      }\n\n      if (request.httpMethod() == \"OPTIONS\" && request.header(\"sec-fetch-mode\") == \"cors\") {\n        response.setStatus(200)\n        response.setBody(\"\")\n        await this.logger.debug(() => [\"Handled preflight OPTIONS request\", {\n          path: request.path(),\n          responseStatusCode: response.getStatusCode()\n        }])\n      } else {\n        await this.logger.debug(\"Run request\")\n        const routesResolver = new RoutesResolver({configuration, request, response})\n        const startTimeMs = Date.now()\n        /** @type {ReturnType<typeof setTimeout> | undefined} */\n        let timeoutId\n        /** @type {((error: Error) => void) | undefined} */\n        let timeoutReject\n        let timedOut = false\n\n        const setRequestTimeoutSeconds = (/** @type {number | undefined} */ timeoutSeconds) => {\n          if (timeoutId) {\n            clearTimeout(timeoutId)\n            timeoutId = undefined\n          }\n\n          if (typeof timeoutSeconds !== \"number\" || !Number.isFinite(timeoutSeconds) || timeoutSeconds <= 0) {\n            return\n          }\n\n          const timeoutMs = timeoutSeconds * 1000\n          const elapsedMs = Date.now() - startTimeMs\n          const remainingMs = timeoutMs - elapsedMs\n\n          if (remainingMs <= 0) {\n            timeoutReject?.(new Error(`Request timed out after ${timeoutSeconds}s`))\n            return\n          }\n\n          timeoutId = setTimeout(() => {\n            timeoutReject?.(new Error(`Request timed out after ${timeoutSeconds}s`))\n          }, remainingMs)\n        }\n\n        const timeoutPromise = new Promise((_, reject) => {\n          timeoutReject = (error) => {\n            timedOut = true\n            reject(error)\n          }\n        })\n\n        response.setRequestTimeoutMsChangeHandler((timeoutSeconds) => {\n          setRequestTimeoutSeconds(timeoutSeconds)\n        })\n\n        setRequestTimeoutSeconds(configuration.getRequestTimeoutMs?.())\n\n        let resolvePromise\n\n        try {\n          resolvePromise = routesResolver.resolve()\n          // Keep Promise.race here to allow dynamic timeout updates.\n          await Promise.race([resolvePromise, timeoutPromise])\n          await this.logger.debug(() => [\"Routes resolver done\", {\n            httpMethod: request.httpMethod(),\n            path: request.path(),\n            responseStatusCode: response.getStatusCode(),\n            hasFilePath: Boolean(response.getFilePath()),\n            bodyType: responseBodyTypeForLog(response)\n          }])\n        } catch (error) {\n          if (timedOut && resolvePromise) {\n            void resolvePromise.catch((resolveError) => {\n              this.logger.warn(() => [\"Request finished after timeout\", resolveError])\n            })\n          }\n          throw error\n        } finally {\n          if (timeoutId) clearTimeout(timeoutId)\n        }\n      }\n    } catch (e) {\n      const error = ensureError(e)\n      const errorWithContext = /** @type {{velociousContext?: object}} */ (error)\n      const errorContext = errorWithContext.velociousContext || {stage: \"request-runner\"}\n      const logDetails = requestErrorLogDetails(error)\n\n      await this.logger.error(() => requestErrorLogMessage(logDetails))\n\n      const errorPayload = {\n        context: errorContext,\n        error,\n        request,\n        response\n      }\n\n      configuration.getErrorEvents().emit(\"framework-error\", errorPayload)\n      configuration.getErrorEvents().emit(\"all-error\", {\n        ...errorPayload,\n        errorType: \"framework-error\"\n      })\n\n      response.setStatus(500)\n      response.setErrorBody(error)\n    }\n\n    await this.logger.debug(() => [\"Request runner done\", {\n      httpMethod: request.httpMethod(),\n      path: request.path(),\n      responseStatusCode: response.getStatusCode()\n    }])\n    this.state = \"done\"\n    this.events.emit(\"done\", this)\n  }\n\n  /** @returns {Promise<void>} - Logs the completed request line after the response has been served. */\n  async logCompletedRequest() {\n    if (this.completedRequestLogged) return\n\n    this.completedRequestLogged = true\n\n    const requestTiming = this.requestTiming\n\n    requestTiming.markResponseServed()\n\n    if (!requestTiming.completedLogSubject || !requestTiming.completedLogMethod) return\n\n    const logger = new Logger(requestTiming.completedLogSubject, {configuration: this.configuration})\n    const summary = requestTiming.summary()\n    const response = this.response\n    const completedMessage = [\n      `Completed ${response.getStatusCode()} ${response.getStatusMessage()} in ${Math.round(summary.totalMs)}ms (`,\n      `Controller: ${formatBucketMs(summary.controllerMs)}`,\n      ` | Views: ${formatBucketMs(summary.viewsMs)}`,\n      ` | DB: ${formatBucketMs(summary.dbMs)} (${queryCountLabel(summary.dbQueryCount)})`,\n      ` | Velocious: ${formatBucketMs(summary.velociousMs)}`,\n      `)`\n    ].join(\"\")\n\n    await logger[requestTiming.completedLogMethod](completedMessage)\n  }\n}\n"]}