{"version":3,"sources":["../../../src/utils/logger.ts","../../../src/utils/file-system-adapter.ts","../../../src/utils/config-validator.ts","../../../src/utils/config.ts","../../../src/utils/doc-sections.ts","../../../src/services/issue-service.ts","../../../src/services/pathname-service.ts","../../../src/services/intent-service.ts","../../../src/services/file-service.ts","../../../src/validation/file-format-validator.ts","../../../src/validation/metadata-format-validator.ts","../../../src/validation/file-system-validator.ts","../../../src/services/plugin-service.ts","../../../src/utils/id-generator.ts","../../../src/utils/plugin-loader.ts","../../../src/LLMail.ts","../../../src/cli/done.ts"],"names":["winston","chalk","path","fs","createReadStream","createWriteStream","load","dump","DEFAULT_SCHEMA","_a","timestamp","join","customAlphabet","require","createRequire","yargs","hideBin"],"mappings":"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","file":"done.cjs","sourcesContent":["import winston from 'winston';\nimport chalk from 'chalk';\nimport { IssueError, FileNotFoundError, InvalidFilenameError, InvalidTargetError, FileExistsError, handleError } from '../errors/errors.js';\n\n// Define our custom logger interface\nexport interface CustomLogger extends winston.Logger {\n  success(message: any, ...meta: any[]): winston.Logger;\n  debug(message: any, ...meta: any[]): winston.Logger;\n}\n\nconst { format, createLogger, transports } = winston;\nconst { combine, timestamp, printf } = format;\n\n// Custom format for different log levels\nconst customFormat = printf((info: winston.Logform.TransformableInfo) => {\n  const ts = new Date(info.timestamp?.toString() || Date.now()).toLocaleTimeString();\n  \n  switch (info.level) {\n    case 'error':\n      return `${chalk.gray(ts)} ${chalk.red('✖')} ${chalk.red(info.message)}`;\n    case 'warn':\n      return `${chalk.gray(ts)} ${chalk.yellow('⚠')} ${chalk.yellow(info.message)}`;\n    case 'info':\n      return `${chalk.gray(ts)} ${chalk.blue('ℹ')} ${info.message}`;\n    case 'debug':\n      return `${chalk.gray(ts)} ${chalk.gray('🔍')} ${chalk.gray(info.message)}`;\n    case 'success':\n      return `${chalk.gray(ts)} ${chalk.green('✔')} ${chalk.green(info.message)}`;\n    default:\n      return `${chalk.gray(ts)} ${info.message}`;\n  }\n});\n\n// Create custom success level\nconst customLevels = {\n  levels: {\n    error: 0,\n    warn: 1,\n    info: 2,\n    debug: 3,\n    success: 4\n  },\n  colors: {\n    error: 'red',\n    warn: 'yellow',\n    info: 'blue',\n    debug: 'gray',\n    success: 'green'\n  }\n};\n\n// Create a filter to completely silence debug messages unless explicitly enabled\nconst silenceDebug = format((info) => {\n  if (info.level === 'debug' && !process.env.DEBUG_ENABLED) {\n    return false;\n  }\n  return info;\n});\n\n// Create the logger with silent debug by default\nconst baseLogger = createLogger({\n  levels: customLevels.levels,\n  format: combine(\n    silenceDebug(),\n    timestamp(),\n    customFormat\n  ),\n  transports: [\n    new transports.Console({\n      level: 'info'\n    })\n  ]\n});\n\n// Add success method to match our interface\n(baseLogger as any).success = baseLogger.info;\n\nexport const logger = baseLogger as CustomLogger;\n\n// Add colors to winston\nwinston.addColors(customLevels.colors);\n\n// Function to configure logger based on debug flag\nexport function configureLogger(debug: boolean = false) {\n  process.env.DEBUG_ENABLED = debug ? 'true' : '';\n  const level = debug ? 'debug' : 'info';\n  logger.transports.forEach(transport => {\n    if (transport instanceof winston.transports.Console) {\n      transport.level = level;\n    }\n  });\n}\n\n// Re-export error types for convenience\nexport { IssueError, FileNotFoundError, InvalidFilenameError, InvalidTargetError, FileExistsError, handleError }; ","import { createReadStream, createWriteStream } from 'fs';\nimport { promises as fs } from 'fs';\nimport path from 'path';\nimport { PathnameService } from '../services/pathname-service.js';\nimport { logger } from '../utils/logger.js';\n\nexport interface FileSystemAdapter {\n  readFile(path: string): Promise<string>;\n  writeFile(path: string, data: string): Promise<void>;\n  exists(path: string): Promise<boolean>;\n  pathExists(path: string): Promise<boolean>;\n  ensureDir(path: string): Promise<void>;\n  readdir(path: string): Promise<string[]>;\n  move(src: string, dest: string): Promise<void>;\n  remove(path: string): Promise<void>;\n  createReadStream(path: string): NodeJS.ReadableStream;\n  createWriteStream(path: string): NodeJS.WritableStream;\n  stat(path: string): Promise<{ isDirectory(): boolean }>;\n  rename(oldPath: string, newPath: string): Promise<void>;\n  mkdtemp(prefix: string): Promise<string>;\n  rm(path: string, options: { recursive?: boolean; force?: boolean }): Promise<void>;\n}\n\n// Real filesystem implementation\nexport const realFileSystemAdapter: FileSystemAdapter = {\n  async readFile(path: string): Promise<string> {\n    return fs.readFile(path, 'utf8');\n  },\n\n  async writeFile(path: string, data: string): Promise<void> {\n    return fs.writeFile(path, data, 'utf8');\n  },\n\n  async exists(path: string): Promise<boolean> {\n    try {\n      await fs.access(path);\n      return true;\n    } catch {\n      return false;\n    }\n  },\n\n  async pathExists(path: string): Promise<boolean> {\n    return this.exists(path);\n  },\n\n  async ensureDir(path: string): Promise<void> {\n    await fs.mkdir(path, { recursive: true });\n  },\n\n  async readdir(path: string): Promise<string[]> {\n    return fs.readdir(path);\n  },\n\n  async move(src: string, dest: string): Promise<void> {\n    await fs.rename(src, dest);\n  },\n\n  async remove(path: string): Promise<void> {\n    await fs.unlink(path);\n  },\n\n  createReadStream(path: string): NodeJS.ReadableStream {\n    return createReadStream(path);\n  },\n\n  createWriteStream(path: string): NodeJS.WritableStream {\n    return createWriteStream(path);\n  },\n\n  async stat(path: string): Promise<{ isDirectory(): boolean }> {\n    const stats = await fs.stat(path);\n    return {\n      isDirectory: () => stats.isDirectory()\n    };\n  },\n\n  async rename(oldPath: string, newPath: string): Promise<void> {\n    await fs.rename(oldPath, newPath);\n  },\n\n  async mkdtemp(prefix: string): Promise<string> {\n    return fs.mkdtemp(path.join(prefix, ''));\n  },\n\n  async rm(path: string, options: { recursive?: boolean; force?: boolean }): Promise<void> {\n    await fs.rm(path, options);\n  }\n};\n\n/**\n * Wraps a FileSystemAdapter to handle path resolution relative to a root directory.\n * This ensures all paths passed to the underlying adapter are properly prefixed with the root directory.\n */\nexport class RootedFileSystemAdapter implements FileSystemAdapter {\n  constructor(\n    private fs: FileSystemAdapter,\n    private rootDir: string,\n    private pathnameService?: PathnameService\n  ) {\n    // Ensure rootDir is absolute and normalized\n    this.rootDir = path.resolve(rootDir);\n    logger.debug('RootedFileSystemAdapter initialized with rootDir:', this.rootDir);\n  }\n\n  private resolvePath(filePath: string): string {\n    // If pathname service is available, use it to canonicalize the path\n    if (this.pathnameService) {\n      filePath = this.pathnameService.toCanonicalPath(filePath);\n    }\n\n    // Normalize the input path\n    const normalizedPath = path.normalize(filePath);\n    \n    // If it's already absolute\n    if (path.isAbsolute(normalizedPath)) {\n      // If it's already under our root dir, return it as is\n      if (normalizedPath.startsWith(this.rootDir)) {\n        return normalizedPath;\n      }\n      \n      // For any other absolute path, get just the relative portion\n      const projectRoot = path.resolve(process.cwd());\n      let relativePath;\n      \n      if (normalizedPath.startsWith(projectRoot)) {\n        // Get path relative to project root\n        relativePath = path.relative(projectRoot, normalizedPath);\n      } else {\n        // For paths outside project root, use the path relative to root directory\n        relativePath = path.relative('/', normalizedPath);\n      }\n      \n      // Remove any leading directory components that match our root dir structure\n      const rootParts = this.rootDir.split(path.sep).filter(Boolean);\n      const pathParts = relativePath.split(path.sep).filter(Boolean);\n      \n      // Find where the paths diverge\n      let i = 0;\n      while (i < rootParts.length && i < pathParts.length && rootParts[i] === pathParts[i]) {\n        i++;\n      }\n      \n      // Use only the unique part of the path\n      const uniquePath = pathParts.slice(i).join(path.sep);\n      \n      return path.join(this.rootDir, uniquePath);\n    }\n    \n    // For relative paths, just join with root\n    return path.join(this.rootDir, normalizedPath);\n  }\n\n  async readFile(filePath: string): Promise<string> {\n    return this.fs.readFile(this.resolvePath(filePath));\n  }\n\n  async writeFile(filePath: string, content: string): Promise<void> {\n    return this.fs.writeFile(this.resolvePath(filePath), content);\n  }\n\n  async exists(filePath: string): Promise<boolean> {\n    return this.fs.exists(this.resolvePath(filePath));\n  }\n\n  async pathExists(filePath: string): Promise<boolean> {\n    return this.fs.pathExists(this.resolvePath(filePath));\n  }\n\n  async ensureDir(dirPath: string): Promise<void> {\n    return this.fs.ensureDir(this.resolvePath(dirPath));\n  }\n\n  async readdir(dirPath: string): Promise<string[]> {\n    return this.fs.readdir(this.resolvePath(dirPath));\n  }\n\n  async move(src: string, dest: string): Promise<void> {\n    return this.fs.move(this.resolvePath(src), this.resolvePath(dest));\n  }\n\n  async remove(filePath: string): Promise<void> {\n    return this.fs.remove(this.resolvePath(filePath));\n  }\n\n  createReadStream(filePath: string): NodeJS.ReadableStream {\n    return this.fs.createReadStream(this.resolvePath(filePath));\n  }\n\n  createWriteStream(filePath: string): NodeJS.WritableStream {\n    return this.fs.createWriteStream(this.resolvePath(filePath));\n  }\n\n  async stat(filePath: string): Promise<{ isDirectory(): boolean }> {\n    return this.fs.stat(this.resolvePath(filePath));\n  }\n\n  async rename(oldPath: string, newPath: string): Promise<void> {\n    return this.fs.rename(this.resolvePath(oldPath), this.resolvePath(newPath));\n  }\n\n  async mkdtemp(prefix: string): Promise<string> {\n    return this.fs.mkdtemp(this.resolvePath(prefix));\n  }\n\n  async rm(path: string, options: { recursive?: boolean; force?: boolean }): Promise<void> {\n    return this.fs.rm(this.resolvePath(path), options);\n  }\n} ","import { ValidationResult } from '../types.js';\nimport { LlmailConfig, ResolvedConfig } from './config.js';\n\n/**\n * Validates llmail configuration.\n * This is a focused utility that only handles config validation.\n * It ensures the config has the required structure and valid values.\n */\nexport class ConfigValidator {\n  /**\n   * Validate raw llmail configuration\n   */\n  validateConfig(config: LlmailConfig): ValidationResult {\n    const errors: string[] = [];\n\n    // Validate required arrays\n    if (!Array.isArray(config.types_list)) {\n      errors.push('types_list must be an array');\n    }\n\n    // Validate array contents if present\n    if (config.types_list?.some(type => typeof type !== 'string' || !type.match(/^[a-z0-9]+$/))) {\n      errors.push('types_list must contain only lowercase alphanumeric strings without hyphens');\n    }\n    if (config.active_states?.some(state => typeof state !== 'string' || !state.match(/^[a-z0-9]+$/))) {\n      errors.push('active_states must contain only lowercase alphanumeric strings without hyphens');\n    }\n    if (config.inactive_reasons?.some(reason => typeof reason !== 'string' || !reason.match(/^[a-z0-9]+$/))) {\n      errors.push('inactive_reasons must contain only lowercase alphanumeric strings without hyphens');\n    }\n\n    // Check for overlapping states if both arrays are present\n    if (config.active_states?.length > 0 && config.inactive_reasons?.length > 0) {\n      const activeStates = new Set(config.active_states);\n      for (const reason of config.inactive_reasons) {\n        if (activeStates.has(reason)) {\n          errors.push('States cannot be both active and inactive');\n          break;\n        }\n      }\n    }\n\n    // Validate required paths\n    if (!config.issues_dir) {\n      errors.push('issues_dir is required');\n    }\n    if (!config.inbox_dir) {\n      errors.push('inbox_dir is required');\n    }\n\n    // Validate plugins if present\n    if (config.plugins !== undefined) {\n      if (typeof config.plugins === 'string') {\n        // Single plugin string format\n        if (!config.plugins.match(/^[a-z0-9-]+$/)) {\n          errors.push('Plugin name must be lowercase alphanumeric with hyphens');\n        }\n      } else if (Array.isArray(config.plugins)) {\n        // Array format\n        for (const plugin of config.plugins) {\n          if (typeof plugin === 'string') {\n            // String array format\n            if (!plugin.match(/^[a-z0-9-]+$/)) {\n              errors.push('Plugin names must be lowercase alphanumeric with hyphens');\n            }\n          } else if (typeof plugin === 'object' && plugin !== null) {\n            // Object format with config\n            if (!plugin.name?.match(/^[a-z0-9-]+$/)) {\n              errors.push('Plugin names must be lowercase alphanumeric with hyphens');\n            }\n            if (plugin.config !== undefined && (typeof plugin.config !== 'object' || plugin.config === null)) {\n              errors.push('Plugin config must be an object');\n            }\n          } else {\n            errors.push('Invalid plugin configuration format');\n          }\n        }\n      } else {\n        errors.push('Invalid plugins configuration format');\n      }\n    }\n\n    return {\n      valid: errors.length === 0,\n      errors,\n      warnings: []\n    };\n  }\n\n  /**\n   * Validate resolved configuration\n   * This is used after the config has been normalized and paths resolved\n   */\n  validateResolvedConfig(config: ResolvedConfig): ValidationResult {\n    const errors: string[] = [];\n\n    // Validate required arrays are present\n    if (!Array.isArray(config.types_list)) {\n      errors.push('Resolved config must have types_list array');\n    }\n    if (!Array.isArray(config.active_states)) {\n      errors.push('Resolved config must have active_states array');\n    }\n    if (!Array.isArray(config.inactive_reasons)) {\n      errors.push('Resolved config must have inactive_reasons array');\n    }\n\n    // Validate required paths are absolute\n    if (!config.issues_dir?.startsWith('/')) {\n      errors.push('Resolved issues_dir must be absolute path');\n    }\n    if (!config.inbox_dir?.startsWith('/')) {\n      errors.push('Resolved inbox_dir must be absolute path');\n    }\n\n    return {\n      valid: errors.length === 0,\n      errors,\n      warnings: []\n    };\n  }\n} ","import fs from 'fs-extra';\nimport path from 'path';\nimport { dump, load } from 'js-yaml';\nimport { FileSystemAdapter } from './file-system-adapter.js';\nimport { ConfigValidator } from './config-validator.js';\n\n/**\n * Core LLMail configuration interface.\n * All paths are relative to the config file location.\n */\nexport interface LlmailConfig {\n  types_list: string[];\n  active_states: string[];\n  inactive_reasons: string[];\n  issues_dir: string;\n  inbox_dir: string;\n  type_dirs?: string[];\n  plugins?: string | string[] | Array<{\n    name: string;\n    config?: Record<string, any>;\n  }>;\n}\n\nexport type ResolvedConfig = LlmailConfig;\n\nconst defaultConfig: LlmailConfig = {\n  types_list: [],\n  active_states: [],\n  inactive_reasons: [],\n  issues_dir: 'issues',\n  inbox_dir: 'inbox'  // Changed to be relative to root\n};\n\n/**\n * Normalize paths in config.\n * All paths in the config should remain relative to the config file location.\n */\nfunction normalizeConfigPaths(config: LlmailConfig): LlmailConfig {\n  // Normalize paths but keep them relative\n  return {\n    ...config,\n    issues_dir: path.normalize(config.issues_dir),\n    inbox_dir: path.normalize(config.inbox_dir)\n  };\n}\n\n/**\n * Load and validate config from a file\n */\nexport async function loadConfigFromFile(fs: FileSystemAdapter, configPath: string, rootDir: string): Promise<LlmailConfig> {\n  const exists = await fs.exists(configPath);\n  \n  if (!exists) {\n    // Return default config with normalized paths\n    return normalizeConfigPaths(defaultConfig);\n  }\n\n  try {\n    const content = await fs.readFile(configPath);\n    let config: any;\n    \n    try {\n      config = load(content) as LlmailConfig;\n    } catch (err) {\n      throw new Error('Failed to load config');\n    }\n\n    // Merge with defaults, ensuring default types are preserved\n    const mergedConfig = {\n      ...defaultConfig,\n      ...config,\n      // Don't merge arrays - use config values if present, otherwise use defaults\n      types_list: config.types_list || defaultConfig.types_list,\n      active_states: config.active_states || defaultConfig.active_states,\n      inactive_reasons: config.inactive_reasons || defaultConfig.inactive_reasons\n    };\n\n    // Validate config\n    const validator = new ConfigValidator();\n    const result = validator.validateConfig(mergedConfig);\n    if (!result.valid) {\n      throw new Error(`Invalid config: ${result.errors[0]}`);\n    }\n\n    // Normalize paths but keep them relative\n    return normalizeConfigPaths(mergedConfig);\n  } catch (err) {\n    if (err instanceof Error) {\n      throw err;\n    }\n    throw new Error('Failed to load config');\n  }\n}\n\n/**\n * Load llmail config from the default location or specified path\n */\nexport async function loadLlmailConfig(fs: FileSystemAdapter, rootDir: string = process.cwd(), configPath?: string): Promise<LlmailConfig> {\n  const resolvedConfigPath = configPath || path.join(rootDir, 'llmail.yaml');\n  try {\n    return await loadConfigFromFile(fs, resolvedConfigPath, rootDir);\n  } catch (err) {\n    // If config file doesn't exist or can't be loaded, return defaults with normalized paths\n    return normalizeConfigPaths(defaultConfig);\n  }\n}\n\n/**\n * Save config to the default location\n */\nexport async function saveLlmailConfig(fs: FileSystemAdapter, config: LlmailConfig, configPath: string): Promise<void> {\n  const yamlContent = dump(normalizeConfigPaths(config));\n  \n  // Ensure the directory exists\n  const configDir = path.dirname(configPath);\n  await fs.ensureDir(configDir);\n  \n  await fs.writeFile(configPath, yamlContent);\n} ","import { load, dump } from 'js-yaml';\n\nexport interface DocSections {\n  frontmatter: string;\n  frontmatterObj: Record<string, any>;\n  content: string;\n  xml: string;\n}\n\nconst YAML_DUMP_OPTIONS = {\n  lineWidth: -1,\n  noRefs: true,\n  sortKeys: true\n};\n\n// Regex to match XML blocks at the bottom of the file\nconst XML_CONTAINER_REGEX = /<XML>([\\s\\S]*?)<\\/XML>/gi;\n\n// Regex to match frontmatter section\nconst FRONTMATTER_REGEX = /^---\\n([\\s\\S]*?)\\n---\\n([\\s\\S]*)$/;\n\nexport function parseDocSections(fileString: string): DocSections {\n  // First try to extract frontmatter\n  const frontmatterMatch = fileString.match(FRONTMATTER_REGEX);\n  let frontmatterRaw = '';\n  let frontmatterObj: Record<string, any> = {};\n  let contentSection = fileString;\n  let xmlSection = '';\n\n  if (!frontmatterMatch) {\n    // No frontmatter, look for XML blocks in the entire file\n    const xmlMatches = [...contentSection.matchAll(XML_CONTAINER_REGEX)];\n    if (xmlMatches.length > 0) {\n      // Combine all XML content\n      xmlSection = xmlMatches.map(m => m[1].trim()).join('\\n\\n');\n      // Remove all XML blocks from content\n      contentSection = contentSection.replace(XML_CONTAINER_REGEX, '').trim();\n    } else {\n      contentSection = fileString.trim();\n    }\n  } else {\n    frontmatterRaw = frontmatterMatch[1];\n    const rest = frontmatterMatch[2];\n\n    try {\n      frontmatterObj = load(frontmatterRaw) || {};\n    } catch {\n      // If invalid YAML, frontmatterObj remains {}\n    }\n\n    // Look for XML blocks in the rest of the content\n    const xmlMatches = [...rest.matchAll(XML_CONTAINER_REGEX)];\n    if (xmlMatches.length > 0) {\n      // Combine all XML content\n      xmlSection = xmlMatches.map(m => m[1].trim()).join('\\n\\n');\n      // Remove all XML blocks from content\n      contentSection = rest.replace(XML_CONTAINER_REGEX, '').trim();\n    } else {\n      contentSection = rest.trim();\n    }\n  }\n\n  return {\n    frontmatter: frontmatterRaw.trim(),\n    frontmatterObj,\n    content: contentSection,\n    xml: xmlSection\n  };\n}\n\nexport function rebuildDocSections(sections: DocSections): string {\n  const frontmatterStr = dump(sections.frontmatterObj, YAML_DUMP_OPTIONS);\n  let result = '';\n\n  // Add frontmatter if we have any frontmatter object properties\n  if (Object.keys(sections.frontmatterObj).length > 0) {\n    result += `---\\n${frontmatterStr}---\\n\\n`;\n  }\n\n  // Add content if present\n  if (sections.content) {\n    result += `${sections.content.trim()}\\n`;\n    // Only add extra newline if we have XML content\n    if (sections.xml) {\n      result += '\\n';\n    }\n  }\n\n  // Add XML section if present\n  if (sections.xml) {\n    result += `<XML>\\n${sections.xml.trim()}\\n</XML>\\n`;\n  }\n\n  return result;\n}\n\nexport function ensureTimestamps(meta: Record<string, any>): void {\n  const now = new Date().toISOString();\n  if (!meta.created) {\n    meta.created = now;\n  }\n  meta.updated = now;\n} ","import { FrontmatterMetadata, ValidationResult } from '../types.js';\nimport { FileSystemAdapter } from '../utils/file-system-adapter.js';\nimport { PathnameService } from './pathname-service.js';\nimport { load, dump, DEFAULT_SCHEMA, DumpOptions } from 'js-yaml';\nimport path from 'path';\nimport { logger } from '../utils/logger.js';\nimport { IntentService } from './intent-service.js';\nimport { FileService } from './file-service.js';\nimport { FileFormatValidator } from '../validation/file-format-validator.js';\nimport { MetadataFormatValidator } from '../validation/metadata-format-validator.js';\nimport { FileSystemValidator } from '../validation/file-system-validator.js';\nimport { ResolvedConfig } from '../utils/config.js';\nimport { PluginService } from './plugin-service.js';\nimport { parseDocSections, rebuildDocSections } from '../utils/doc-sections.js';\nimport { join } from 'path';\n\ninterface UpdateMetadata {\n  author?: string;\n  reason?: string;\n  [key: string]: string | undefined;\n}\n\ninterface UpdateOptions {\n  id: string;\n  content: string;\n  metadata?: UpdateMetadata;\n  time?: boolean;\n}\n\ninterface XMLOptions {\n  id: string;\n  tagName: string;\n  content: string;\n  metadata?: Record<string, string>;\n  time?: boolean;\n}\n\nexport class IssueService {\n  private readonly FRONTMATTER_REGEX = /^---\\n([\\s\\S]*?\\n)---\\n([\\s\\S]*)$/;\n\n  // YAML dump options for consistent frontmatter formatting\n  private readonly YAML_DUMP_OPTIONS: DumpOptions = {\n    lineWidth: -1,\n    noRefs: true,\n    schema: DEFAULT_SCHEMA,\n    styles: {\n      '!!null': 'lowercase',\n      '!!bool': 'lowercase',\n      '!!str': 'double'\n    },\n    quotingType: '\"' as const,\n    forceQuotes: true\n  };\n\n  private config: ResolvedConfig;\n  private pathnameService: PathnameService;\n  private fs: FileSystemAdapter;\n  private intentService: IntentService;\n  private fileService: FileService;\n  private fileFormatValidator: FileFormatValidator;\n  private metadataValidator: MetadataFormatValidator;\n  private fileSystemValidator: FileSystemValidator;\n  private pluginService?: PluginService;\n\n  constructor(\n    pathnameService: PathnameService,\n    fs: FileSystemAdapter,\n    intentService: IntentService,\n    fileService: FileService,\n    fileFormatValidator: FileFormatValidator,\n    metadataValidator: MetadataFormatValidator,\n    fileSystemValidator: FileSystemValidator,\n    pluginService?: PluginService\n  ) {\n    this.pathnameService = pathnameService;\n    this.fs = fs;\n    this.intentService = intentService;\n    this.fileService = fileService;\n    this.fileFormatValidator = fileFormatValidator;\n    this.metadataValidator = metadataValidator;\n    this.fileSystemValidator = fileSystemValidator;\n    this.pluginService = pluginService;\n    this.config = pathnameService.getConfig();\n  }\n\n  fileMethods = {\n    writeNewFile: async (metadata: FrontmatterMetadata, content: string = ''): Promise<string> => {\n      // Clean and validate metadata\n      const cleanedMeta = this.metadataValidator.cleanMetadata(metadata);\n      const validation = this.validateMetadata(cleanedMeta);\n      if (!validation.valid) {\n        throw new Error(validation.errors.join(', '));\n      }\n\n      // Create document sections\n      const sections = {\n        frontmatter: dump({\n          ...cleanedMeta,\n          created: new Date().toISOString()\n        }, this.YAML_DUMP_OPTIONS),\n        frontmatterObj: {\n          ...cleanedMeta,\n          created: new Date().toISOString()\n        },\n        content: content.trim(),\n        xml: ''\n      };\n\n      // Build the document\n      const fullContent = rebuildDocSections(sections);\n\n      // Get path based on metadata\n      const location = this.pathnameService.deriveFileLocation(cleanedMeta);\n      const filePath = path.join(location.dirname, location.basename);\n\n      // Ensure target directory exists\n      await this.fileService.ensureDir(location.dirname);\n\n      // Write file atomically\n      await this.fileService.writeFile(filePath, fullContent);\n      \n      return filePath;\n    },\n\n    saveAndMoveFile: async (filePath: string, metadata: FrontmatterMetadata): Promise<string> => {\n      // Let IntentService interpret the metadata\n      const interpretedMeta = this.intentService.interpretMetadata(metadata);\n\n      // Clean and validate the transition\n      const currentMeta = await this.frontmatterMethods.getFrontmatterMetadata(filePath);\n      \n      const updatedMeta = this.intentService.cleanStateTransition(currentMeta || metadata, interpretedMeta);\n\n      // Get new path based on interpreted metadata\n      const location = this.pathnameService.deriveFileLocation(updatedMeta);\n      const newPath = path.join(location.dirname, location.basename);\n\n      // Read current content and update frontmatter\n      const content = await this.fileService.readFile(filePath);\n      const newContent = this.frontmatterMethods.updateFrontmatter(content, updatedMeta);\n\n      // Normalize paths before comparison\n      const normalizedNewPath = path.normalize(newPath);\n      const normalizedFilePath = path.normalize(filePath);\n\n      // If path is changing, use atomic move which will handle cleanup\n      if (normalizedNewPath !== normalizedFilePath) {\n        await this.fileService.atomicMove(filePath, newPath, newContent);\n      } else {\n        // Otherwise just update content in place\n        await this.fileService.writeFile(filePath, newContent);\n      }\n\n      return newPath;\n    },\n\n    moveFileWithMetadata: async (sourcePath: string, targetPath: string, metadata: FrontmatterMetadata): Promise<void> => {\n      // Get current metadata\n      const currentMeta = await this.frontmatterMethods.getFrontmatterMetadata(sourcePath);\n      if (!currentMeta) {\n        throw new Error('No frontmatter found');\n      }\n\n      // Merge with new metadata (new values take precedence)\n      const mergedMeta = {\n        ...currentMeta,  // Start with all current metadata\n        ...metadata,     // Override with new metadata\n        created: currentMeta.created  // Always preserve created timestamp\n      };\n\n      // Let IntentService interpret the metadata\n      const interpretedMeta = this.intentService.interpretMetadata(mergedMeta);\n      \n      // Clean and validate metadata before move\n      const cleanedMeta = this.metadataValidator.cleanMetadata(interpretedMeta);\n      const validation = this.validateMetadata(cleanedMeta);\n      if (!validation.valid) {\n        throw new Error(`Invalid metadata: ${validation.errors.join(', ')}`);\n      }\n\n      // Read current content and update frontmatter\n      const content = await this.fileService.readFile(sourcePath);\n      \n      // Ensure we preserve the state in the frontmatter only if it exists\n      const frontmatterToWrite = {\n        ...cleanedMeta,\n        ...('state' in metadata && { state: metadata.state })  // Only preserve state if it exists as a property\n      };\n      const newContent = this.frontmatterMethods.updateFrontmatter(content, frontmatterToWrite);\n      \n      // Get target path based on metadata\n      const location = this.pathnameService.deriveFileLocation(cleanedMeta);\n      const derivedTargetPath = path.join(location.dirname, location.basename);\n      \n      // Use derived path if no target path is provided\n      const finalTargetPath = targetPath || derivedTargetPath;\n\n      // Normalize paths for comparison\n      const normalizedSource = path.normalize(sourcePath);\n      const normalizedTarget = path.normalize(finalTargetPath);\n\n      // Perform atomic move with backup\n      await this.fileService.withBackup(normalizedSource, async () => {\n        if (normalizedSource !== normalizedTarget) {\n          await this.fileService.atomicMove(normalizedSource, normalizedTarget, newContent);\n        } else {\n          await this.fileService.writeFile(normalizedSource, newContent);\n        }\n      });\n    },\n\n    findFilesByState: async (state: string): Promise<string[]> => {\n      // Let IntentService determine valid paths and state interpretation\n      const stateInfo = this.intentService.interpretState(state);\n      const paths = this.pathnameService.getPossiblePathsForState(state);\n      \n      const files = await this.fileService.findFiles((f) => f.endsWith('.md'), paths);\n      const results: string[] = [];\n      \n      for (const file of files) {\n        const meta = await this.frontmatterMethods.getFrontmatterMetadata(file);\n        if (!meta) continue;\n        \n        // Special handling for inbox state\n        if (state === 'inbox') {\n          // For inbox, we only care about the file location and active status\n          const normalizedFile = path.normalize(file);\n          const normalizedInbox = path.normalize(this.config.inbox_dir);\n          \n          if (normalizedFile.startsWith(normalizedInbox) && meta.active === true) {\n            results.push(file);\n          }\n          continue;\n        }\n        \n        // For other states, let IntentService determine if file matches\n        if (this.intentService.matchesState(meta, stateInfo)) {\n          // Get canonical path based on metadata\n          const location = this.pathnameService.deriveFileLocation(meta);\n          const canonicalPath = path.join(location.dirname, location.basename);\n          \n          // Normalize paths for comparison\n          const normalizedFile = path.normalize(file);\n          const normalizedCanonical = path.normalize(canonicalPath);\n          \n          // Only add if the file is in the correct location\n          if (normalizedFile === normalizedCanonical) {\n            results.push(canonicalPath);\n          }\n        }\n      }\n      return results;\n    },\n\n    getMetadataFromPath: async (filePath: string): Promise<FrontmatterMetadata | null> => {\n      try {\n        const content = await this.fileService.readFile(filePath);\n        const frontmatter = await this.frontmatterMethods.parseFrontmatter(content);\n        if (!frontmatter) {\n          return null;\n        }\n        return frontmatter as FrontmatterMetadata;\n      } catch (error: any) {\n        // Only catch \"file not found\" errors\n        if (error.message === 'File not found') {\n          return null;\n        }\n        throw error;\n      }\n    },\n\n    findFileById: async (id: string): Promise<string | undefined> => {\n      const searchDirs = this.pathnameService.getPossiblePathsForId(id);\n      \n      const matches: { path: string; meta: FrontmatterMetadata | null }[] = [];\n      const errors: { path: string; error: Error }[] = [];\n      \n      for (const dir of searchDirs) {\n        const filesInDir = await this.fileService.findFiles((f) => f.endsWith('.md'), [dir]);\n        \n        for (const file of filesInDir) {\n          if (!this.pathnameService.matchesId(path.basename(file), id)) {\n            continue;\n          }\n\n          try {\n            const meta = await this.fileMethods.getMetadataFromPath(file);\n            \n            // Skip files with no metadata or no ID\n            if (!meta || !meta.id) {\n              continue;\n            }\n\n            // If metadata exists and has an ID, it must match exactly\n            if (meta.id.toLowerCase() !== id.toLowerCase()) {\n              // Throw immediately if IDs don't match\n              throw new Error(`System integrity error: File ${file} has ID that does not match filename (${meta.id} vs ${id})`);\n            }\n            matches.push({ path: file, meta });\n          } catch (error: any) {\n            // Always rethrow system integrity errors\n            if (error.message.includes('System integrity error')) {\n              throw error;\n            }\n            errors.push({ path: file, error });\n          }\n        }\n      }\n\n      if (errors.length > 0) {\n        const errorDetails = errors.map(e => `${e.path} (${e.error.message})`).join(', ');\n        throw new Error(`System integrity error: Failed to parse metadata in files: ${errorDetails}`);\n      }\n\n      // Only consider matches where metadata ID matches exactly if present\n      const validMatches = matches.filter(m => !m.meta?.id || m.meta.id.toLowerCase() === id.toLowerCase());\n\n      if (validMatches.length > 1) {\n        const foundFiles = validMatches.map(m => m.path).join(', ');\n        throw new Error(`System integrity error: Multiple files found for ID ${id}: ${foundFiles}`);\n      }\n\n      return validMatches[0]?.path;\n    },\n\n    findFilesByType: async (type: string): Promise<string[]> => {\n      const paths = this.pathnameService.getPossiblePathsForType(type);\n      const files = await this.fileService.findFiles((f) => f.endsWith('.md'), paths);\n      const results: string[] = [];\n      for (const file of files) {\n        const meta = await this.fileMethods.getMetadataFromPath(file);\n        if (meta?.type === type) {\n          results.push(file);\n        }\n      }\n      return results;\n    }\n  };\n\n  frontmatterMethods = {\n    parseFrontmatter: async (content: string): Promise<Record<string, any> | null> => {\n      // Use doc-sections to parse the content\n      const sections = parseDocSections(content);\n      return sections.frontmatterObj || null;\n    },\n\n    updateFrontmatter: (content: string, frontmatter: FrontmatterMetadata): string => {\n      // Parse the document using doc-sections\n      const sections = parseDocSections(content);\n      \n      // Update the frontmatter object\n      sections.frontmatterObj = frontmatter;\n      sections.frontmatter = dump(frontmatter, this.YAML_DUMP_OPTIONS);\n\n      // Rebuild the document with the new frontmatter\n      return rebuildDocSections(sections);\n    },\n\n    createFrontmatter: async (metadata: FrontmatterMetadata): Promise<string> => {\n      const frontmatter = {\n        ...metadata,\n        created: new Date().toISOString()\n      };\n\n      // Create a new document with only frontmatter\n      const sections = {\n        frontmatter: dump(frontmatter, this.YAML_DUMP_OPTIONS),\n        frontmatterObj: frontmatter,\n        content: '',\n        xml: ''\n      };\n\n      // Build the document\n      return rebuildDocSections(sections);\n    },\n\n    getFrontmatterMetadata: async (filePath: string): Promise<FrontmatterMetadata | null> => {\n      try {\n        const content = await this.fileService.readFile(filePath);\n        const sections = parseDocSections(content);\n        // Return null if there is no frontmatter or if frontmatterObj is empty\n        if (!sections.frontmatter || Object.keys(sections.frontmatterObj).length === 0) {\n          return null;\n        }\n        return sections.frontmatterObj as FrontmatterMetadata;\n      } catch (error: any) {\n        if (error.message === 'File not found') {\n          return null;\n        }\n        throw error;\n      }\n    },\n\n    isValidFrontmatterMetadata: (meta: any): meta is FrontmatterMetadata => {\n      return (\n        typeof meta === 'object' &&\n        meta !== null &&\n        typeof meta.id === 'string' &&\n        typeof meta.type === 'string' &&\n        typeof meta.active === 'boolean'\n      );\n    },\n\n    validateMetadata: (metadata: FrontmatterMetadata): ValidationResult => {\n      // First validate format\n      const formatValidation = this.metadataValidator.validateFormat(metadata);\n      if (!formatValidation.valid) {\n        return formatValidation;\n      }\n\n      // Then apply plugin validation chain if plugins exist\n      if (this.pluginService) {\n        const pluginValidation = this.xmlMethods.applyPluginValidation(metadata);\n        if (!pluginValidation.valid) {\n          return pluginValidation;\n        }\n\n        // If plugin validation passed but had warnings, merge them with config validation\n        const configValidation = this.intentService.validateMetadataAgainstConfig(metadata);\n        return {\n          valid: configValidation.valid,\n          errors: configValidation.errors,\n          warnings: [...pluginValidation.warnings, ...configValidation.warnings]\n        };\n      }\n\n      // Finally validate against config/business rules\n      return this.intentService.validateMetadataAgainstConfig(metadata);\n    },\n\n    validateStateTransition: (current: FrontmatterMetadata, next: FrontmatterMetadata): ValidationResult => {\n      return this.intentService.validateStateTransition(\n        { pathname: '', metadata: current },\n        { pathname: '', metadata: next }\n      );\n    },\n\n    markAsDone: async (id: string, reason: string): Promise<string> => {\n      const filePath = await this.fileMethods.findFileById(id);\n      if (!filePath) {\n        throw new Error(`File not found for id: ${id}`);\n      }\n\n      // Update metadata with done state\n      const updates: Partial<FrontmatterMetadata> = {\n        active: false,\n        state: reason || 'done',\n        inactive_timestamp: new Date().toISOString()\n      };\n\n      // Apply the state transition\n      await this.frontmatterMethods.transitionActiveState(filePath, updates);\n\n      return filePath;\n    },\n\n    setFrontmatterMetadata: async (filePath: string, updates: Partial<FrontmatterMetadata>): Promise<string> => {\n      // Get current metadata\n      const currentMeta = await this.frontmatterMethods.getFrontmatterMetadata(filePath);\n      if (!currentMeta) {\n        throw new Error('No frontmatter found');\n      }\n\n      // Merge updates with current metadata\n      const updatedMeta = {\n        ...currentMeta,\n        ...updates\n      };\n\n      // Let IntentService interpret the metadata\n      const interpretedMeta = this.intentService.interpretMetadata(updatedMeta);\n\n      // Get new path based on interpreted metadata\n      const location = this.pathnameService.deriveFileLocation(interpretedMeta);\n      const newPath = path.join(location.dirname, location.basename);\n\n      // Read current content and update frontmatter\n      const content = await this.fileService.readFile(filePath);\n      const newContent = this.frontmatterMethods.updateFrontmatter(content, interpretedMeta);\n\n      // Normalize paths before comparison\n      const normalizedNewPath = path.normalize(newPath);\n      const normalizedFilePath = path.normalize(filePath);\n\n      // If path is changing, use atomic move which will handle cleanup\n      if (normalizedNewPath !== normalizedFilePath) {\n        await this.fileService.atomicMove(filePath, newPath, newContent);\n      } else {\n        // Otherwise just update content in place\n        await this.fileService.writeFile(filePath, newContent);\n      }\n\n      return newPath;\n    },\n\n    transitionActiveState: async (filePath: string, next: Partial<FrontmatterMetadata>): Promise<void> => {\n      const currentMeta = await this.frontmatterMethods.getFrontmatterMetadata(filePath);\n      if (!currentMeta) {\n        throw new Error('Could not get current metadata');\n      }\n\n      // Let IntentService interpret the metadata\n      const interpretedMeta = this.intentService.interpretMetadata(next);\n\n      // Clean and validate the transition\n      const updatedMeta = this.intentService.cleanStateTransition(currentMeta, interpretedMeta);\n      const validation = this.frontmatterMethods.validateStateTransition(currentMeta, updatedMeta);\n      if (!validation.valid) {\n        throw new Error(`Invalid state transition: ${validation.errors.join(', ')}`);\n      }\n\n      // Get new path and move file\n      const location = this.pathnameService.deriveFileLocation(updatedMeta);\n      const newPath = path.join(location.dirname, location.basename);\n\n      // Read current content and update frontmatter\n      const content = await this.fileService.readFile(filePath);\n      const newContent = this.frontmatterMethods.updateFrontmatter(content, updatedMeta);\n\n      // Write to new location atomically\n      await this.fileService.atomicMove(filePath, newPath, newContent);\n    }\n  };\n\n  xmlMethods = {\n    formatXMLAttributes: (metadata: Record<string, string> = {}, timestamp: string | false = false): string => {\n      const attrs: string[] = [];\n      \n      // Add timestamp first if provided\n      if (timestamp !== false) {\n        attrs.push(`time=\"${timestamp}\"`);\n      }\n      \n      // Add all other metadata attributes\n      for (const [key, value] of Object.entries(metadata)) {\n        if (value !== undefined) {\n          // Escape quotes in attribute values\n          const escapedValue = value.replace(/\"/g, '&quot;');\n          attrs.push(`${key}=\"${escapedValue}\"`);\n        }\n      }\n      \n      return attrs.length > 0 ? ' ' + attrs.join(' ') : '';\n    },\n\n    createXMLBlock: (tagName: string, content: string, metadata?: Record<string, string>, includeTime: boolean = false): string => {\n      const timestamp = includeTime ? new Date().toISOString() : false;\n      const attributes = this.xmlMethods.formatXMLAttributes(metadata, timestamp);\n      \n      // Ensure content has proper line endings and no extra whitespace\n      const normalizedContent = content.trim();\n      \n      // Return XML block with proper spacing - single newline within block\n      return `<${tagName}${attributes}>\\n${normalizedContent}\\n</${tagName}>`;\n    },\n\n    prependXML: async (options: XMLOptions): Promise<void> => {\n      const { id, tagName, content, metadata, time = false } = options;\n\n      // Find the file using findFileById\n      const filePath = await this.fileMethods.findFileById(id);\n      if (!filePath) {\n        throw new Error(`File not found for id: ${id}`);\n      }\n\n      // Read current content\n      const currentContent = await this.fileService.readFile(filePath);\n\n      // Parse using doc-sections\n      const sections = parseDocSections(currentContent);\n\n      // Create new XML block\n      const xmlBlock = this.xmlMethods.createXMLBlock(tagName, content, metadata, time);\n\n      // Prepend the new block to existing XML content with proper spacing\n      sections.xml = sections.xml\n        ? `${xmlBlock}\\n\\n${sections.xml.trim()}`\n        : xmlBlock;\n\n      // Rebuild the document\n      const newContent = rebuildDocSections(sections);\n\n      // Write updated content atomically\n      await this.fileService.writeFile(filePath, newContent);\n    },\n\n    appendXML: async (options: XMLOptions): Promise<void> => {\n      const { id, tagName, content, metadata, time = false } = options;\n\n      // Find the file using findFileById\n      const filePath = await this.fileMethods.findFileById(id);\n      if (!filePath) {\n        throw new Error(`File not found for id: ${id}`);\n      }\n\n      // Read current content\n      const currentContent = await this.fileService.readFile(filePath);\n\n      // Parse using doc-sections\n      const sections = parseDocSections(currentContent);\n\n      // Create new XML block\n      const xmlBlock = this.xmlMethods.createXMLBlock(tagName, content, metadata, time);\n\n      // Append the new block to existing XML content with proper spacing\n      sections.xml = sections.xml\n        ? `${sections.xml.trim()}\\n\\n${xmlBlock}`\n        : xmlBlock;\n\n      // Rebuild the document\n      const newContent = rebuildDocSections(sections);\n\n      // Write updated content atomically\n      await this.fileService.writeFile(filePath, newContent);\n    },\n\n    prependUpdate: async (options: UpdateOptions): Promise<void> => {\n      const { metadata, ...rest } = options;\n      // Convert UpdateMetadata to Record<string, string> by filtering out undefined values\n      const cleanedMetadata = metadata ? \n        Object.fromEntries(\n          Object.entries(metadata)\n            .filter(([_, value]) => value !== undefined)\n            .map(([key, value]) => [key, value as string])  // Assert non-undefined values are strings\n        ) as Record<string, string> : undefined;\n\n      await this.xmlMethods.prependXML({\n        ...rest,\n        tagName: 'Update',\n        time: options.time ?? true, // Default to true for Update blocks\n        metadata: cleanedMetadata\n      });\n    },\n\n    appendUpdate: async (options: UpdateOptions): Promise<void> => {\n      const { metadata, ...rest } = options;\n      // Convert UpdateMetadata to Record<string, string> by filtering out undefined values\n      const cleanedMetadata = metadata ? \n        Object.fromEntries(\n          Object.entries(metadata)\n            .filter(([_, value]) => value !== undefined)\n            .map(([key, value]) => [key, value as string])  // Assert non-undefined values are strings\n        ) as Record<string, string> : undefined;\n\n      await this.xmlMethods.appendXML({\n        ...rest,\n        tagName: 'Update',\n        time: options.time ?? true, // Default to true for Update blocks\n        metadata: cleanedMetadata\n      });\n    },\n\n    applyPluginValidation: (metadata: FrontmatterMetadata): ValidationResult => {\n      const result: ValidationResult = { \n        valid: true, \n        errors: [], \n        warnings: []\n      };\n\n      // Get plugins in priority order (already sorted by PluginService)\n      const plugins = this.pluginService!.getPlugins();\n\n      for (const plugin of plugins) {\n        try {\n          if (plugin.validateMetadata) {\n            const pluginResult = plugin.validateMetadata(metadata);\n            \n            // Merge warnings\n            if (pluginResult.warnings) {\n              result.warnings.push(...pluginResult.warnings);\n            }\n\n            // If plugin validation fails, merge errors and mark as invalid\n            if (!pluginResult.valid) {\n              result.valid = false;\n              if (pluginResult.errors) {\n                result.errors.push(...pluginResult.errors);\n              }\n            }\n          }\n        } catch (error: any) {\n          // Log error but continue with other plugins\n          logger.error(`Plugin ${plugin.name} validation failed:`, error);\n          result.warnings.push(`Plugin ${plugin.name} validation error: ${error.message}`);\n        }\n      }\n\n      return result;\n    }\n  };\n\n  // Public methods for validation\n  validateMetadata = this.frontmatterMethods.validateMetadata;\n  validateStateTransition = this.frontmatterMethods.validateStateTransition;\n\n  getIssueDirectories(): string[] {\n    const dirs = [];\n    const paths = this.pathnameService.getActivityDirectories();\n    const issueTypes = this.pathnameService.getConfig().types_list;\n    for (const type of issueTypes) {\n      for (const path of paths) {\n        dirs.push(join(path, type));\n      }\n    }\n    return dirs;\n  }\n} ","import path from 'path';\nimport { FrontmatterMetadata } from '../types.js';\nimport { ResolvedConfig } from '../utils/config.js';\nimport { IntentService } from './intent-service.js';\n\nexport interface ParsedPathname {\n  type: string;\n  id: string;\n  extension?: string;\n  active?: boolean;\n  state?: string;\n}\n\nexport interface FileLocation {\n  dirname: string;\n  basename: string;\n}\n\n/**\n * Service for path manipulation and location determination.\n * Does NOT handle any filesystem operations.\n */\nexport class PathnameService {\n  constructor(\n    private config: ResolvedConfig,\n    private intentService: IntentService\n  ) {}\n\n  // Public getter for config\n  getConfig(): ResolvedConfig {\n    return this.config;\n  }\n\n  // Core Path Operations\n  deriveFileLocation(metadata: FrontmatterMetadata): FileLocation {\n    const interpretation = this.intentService.interpretIntent({\n      pathname: '',  // Empty pathname since we're just interpreting metadata\n      metadata\n    });\n\n    // Always return relative paths by stripping any leading slashes\n    const dirname = interpretation.targetLocation.dirname.replace(/^\\/+/, '');\n    const basename = interpretation.targetLocation.basename;\n\n    return {\n      dirname,\n      basename\n    };\n  }\n\n  joinPath(...parts: string[]): string {\n    // Ensure all parts are relative paths by removing any leading slashes\n    const relativeParts = parts.map(part => part.replace(/^\\/+/, ''));\n    return path.join(...relativeParts);\n  }\n\n  resolvePath(pathname: string, from?: string): string {\n    // Always work with relative paths\n    const relativePath = pathname.replace(/^\\/+/, '');\n    const relativeFrom = from?.replace(/^\\/+/, '') || '';\n    \n    // If from is provided, resolve relative to it, otherwise just normalize the path\n    return from ? path.join(relativeFrom, relativePath) : relativePath;\n  }\n\n  toCanonicalPath(pathname: string): string {\n    // Ensure we're working with a relative path\n    const relativePath = pathname.replace(/^\\/+/, '');\n    return path.normalize(relativePath);\n  }\n\n  // Directory Structure\n  getActivityDirectories(): string[] {\n    const dirs = [\n      this.config.inbox_dir || 'inbox',\n      this.config.issues_dir || 'issues'\n    ];\n\n    // Add active state directories\n    for (const state of this.config.active_states) {\n      if (state !== 'inbox') {\n        dirs.push(path.join(this.config.issues_dir || 'issues', `_${state}`));\n      }\n    }\n\n    // Add type directories only for types that were explicitly configured\n    // Note: We use config.types_list directly since it's no longer modified by IntentService\n    for (const type of this.config.types_list) {\n      dirs.push(path.join(this.config.issues_dir || 'issues', type));\n    }\n\n    return dirs;\n  }\n\n  getStateFullPath(state: string): string {\n    if (state === 'inbox') {\n      return this.config.inbox_dir || 'inbox';\n    }\n    return path.join(this.config.issues_dir || 'issues', `_${state}`);\n  }\n\n  getTypeDirs(): string[] {\n    return this.config.types_list.map(type => \n      path.join(this.config.issues_dir || 'issues', type)\n    );\n  }\n\n  // Path Parsing\n  parsePathname(pathname: string): ParsedPathname | null {\n    const parts = pathname.split('/');\n    const dirname = parts.slice(0, -1).join('/');\n    const basename = parts[parts.length - 1];\n\n    // Check if in active state directory\n    const isInActiveStateDir = parts.some(part => part.startsWith('_'));\n    const activeState = isInActiveStateDir ? parts.find(part => part.startsWith('_'))?.substring(1) : undefined;\n\n    // Match type and id from basename\n    const match = basename.match(/^(?:([a-zA-Z0-9]+)-)?([a-zA-Z0-9]+)-([a-zA-Z0-9]+)\\..*$/i);\n    if (!match) {\n      // Special case for filenames without extension\n      if (basename.match(/^[a-zA-Z0-9]+$/i)) {\n        return {\n          id: basename,\n          type: '',\n          active: this.isInboxDirectory(dirname)\n        };\n      }\n      return null;\n    }\n\n    const prefix = match[1];\n    const type = match[2];\n    const id = match[3];\n    const extension = path.extname(basename);\n\n    // If in active state directory, use that state\n    if (activeState) {\n      return {\n        type,\n        id,\n        extension,\n        active: true,\n        state: activeState\n      };\n    }\n\n    // If prefix is an inactive reason, use that\n    if (prefix && this.config.inactive_reasons.includes(prefix)) {\n      return {\n        type,\n        id,\n        extension,\n        active: false,\n        state: prefix\n      };\n    }\n\n    // If in inbox directory, mark as active\n    if (this.isInboxDirectory(dirname)) {\n      return {\n        type,\n        id,\n        extension,\n        active: true,\n        state: 'inbox'\n      };\n    }\n\n    // Default case - in type directory means inactive\n    return {\n      type,\n      id,\n      extension,\n      active: false\n    };\n  }\n\n  parseBasename(basename: string): ParsedPathname | null {\n    // Match state/reason, type and id from basename\n    const match = basename.match(/^([a-zA-Z0-9]+)-([a-zA-Z0-9]+)-([a-zA-Z0-9]+)\\..*$/i);\n    if (match) {\n      const prefix = match[1];\n      const type = match[2];\n      const id = match[3];\n\n      // If prefix is a known inactive reason, treat it as such\n      if (this.config.inactive_reasons.includes(prefix)) {\n        return {\n          state: prefix,\n          type,\n          id,\n          active: false\n        };\n      }\n\n      // If prefix is a known active state, treat it as such\n      if (this.config.active_states.includes(prefix)) {\n        return {\n          state: prefix,\n          type,\n          id,\n          active: true\n        };\n      }\n\n      // Otherwise treat first part as type\n      return {\n        type: prefix,\n        id: type\n      };\n    }\n\n    // Match type and id without state/reason\n    const simpleMatch = basename.match(/^([a-zA-Z0-9]+)-([a-zA-Z0-9]+)\\..*$/i);\n    if (simpleMatch) {\n      return {\n        type: simpleMatch[1],\n        id: simpleMatch[2]\n      };\n    }\n\n    // Special case for filenames without extension\n    if (basename.match(/^[a-zA-Z0-9]+$/i)) {\n      return {\n        id: basename,\n        type: ''\n      };\n    }\n\n    return null;\n  }\n\n  // Path Generation\n  getNewPath(pathname: string, metadata: FrontmatterMetadata): string {\n    const location = this.deriveFileLocation(metadata);\n    return this.joinPath(location.dirname, location.basename);\n  }\n\n  // Directory Type Checks\n  isInboxDirectory(dirname: string): boolean {\n    return dirname.toLowerCase() === (this.config.inbox_dir || 'inbox').toLowerCase();\n  }\n\n  isTypeDirectory(dirname: string): boolean {\n    return this.config.types_list.some(type => type.toLowerCase() === dirname.toLowerCase());\n  }\n\n  // Path Matching\n  matchesId(filename: string, id: string): boolean {\n    const parsed = this.parsePathname(filename);\n    return parsed ? parsed.id.toLowerCase() === id.toLowerCase() : false;\n  }\n\n  // Search Path Generation\n  getPossiblePathsForId(id: string): string[] {\n    const paths: string[] = [\n      this.config.inbox_dir || 'inbox',\n      this.config.issues_dir || 'issues',\n      ...this.config.active_states\n        .filter(state => state !== 'inbox')\n        .map(state => path.join(this.config.issues_dir || 'issues', `_${state}`))\n    ];\n\n    // Add type directories only for types that were explicitly configured\n    // Note: We use config.types_list directly since it's no longer modified by IntentService\n    for (const type of this.config.types_list) {\n      paths.push(path.join(this.config.issues_dir || 'issues', type));\n    }\n\n    return paths;\n  }\n\n  getPossiblePathsForType(type: string): string[] {\n    return [\n      this.config.inbox_dir || 'inbox',\n      ...this.config.active_states\n        .filter(state => state !== 'inbox')\n        .map(state => path.join(this.config.issues_dir || 'issues', `_${state}`)),\n      path.join(this.config.issues_dir || 'issues', type)\n    ];\n  }\n\n  getPossiblePathsForState(state: string): string[] {\n    if (state === 'inbox') {\n      return [this.config.inbox_dir || 'inbox'];\n    }\n\n    // For active states, look in _state directory\n    if (this.config.active_states.includes(state)) {\n      return [path.join(this.config.issues_dir || 'issues', `_${state}`)];\n    }\n\n    // For inactive states (reasons), look in each type directory\n    if (this.config.inactive_reasons.includes(state)) {\n      return this.config.types_list.map(type => \n        path.join(this.config.issues_dir || 'issues', type)\n      );\n    }\n\n    // For unknown states, look everywhere\n    return this.getActivityDirectories();\n  }\n\n  /**\n   * Get the canonical path where a NEW file with this ID should be located.\n   * This returns the default location for new files (inbox).\n   * \n   * To find an existing file by ID, use IssueService.findFileById() instead,\n   * as that method handles all the necessary validation and error checking.\n   * \n   * @param id The ID to get the path for\n   * @returns The canonical path where a new file with this ID should be created\n   */\n  getPathForId(id: string): string {\n    // By default, new IDs go to inbox\n    return path.join(this.config.inbox_dir || 'inbox', `${id}.md`);\n  }\n}","import { ResolvedConfig } from '../utils/config.js';\nimport path from 'path';\nimport { FrontmatterMetadata, ValidationResult } from '../types.js';\nimport { PluginService } from './plugin-service.js';\nimport { logger } from '../utils/logger.js';\n\nexport interface FileLocation {\n  dirname: string;\n  basename: string;\n}\n\nexport interface FileState {\n  pathname: string;\n  metadata: FrontmatterMetadata;\n}\n\nexport interface FileIntent {\n  targetDir: string;\n  metadata: FrontmatterMetadata;\n}\n\nexport interface InterpretedIntent {\n  targetLocation: FileLocation;\n  targetMetadata: FrontmatterMetadata;\n  reason: string;\n}\n\nexport interface LocationPattern {\n  inDirectory?: string | ((dir: string) => boolean);\n  hasTypeDir?: boolean;\n}\n\nexport interface MetadataPattern {\n  hasState?: boolean;\n  specificState?: string | ((state: string) => boolean);\n}\n\nexport interface IntentPattern {\n  pattern: {\n    location?: LocationPattern;\n    metadata?: MetadataPattern;\n  };\n  interpretation: (state: FileState) => InterpretedIntent;\n}\n\nexport class IntentService {\n  private intentPatterns: IntentPattern[];\n  private validTypes: string[];\n\n  constructor(\n    private config: ResolvedConfig,\n    private pluginService?: PluginService\n  ) {\n    this.intentPatterns = [];\n    \n    // Initialize valid types from config first\n    this.validTypes = [...config.types_list];\n    logger.debug('Initial validTypes:', this.validTypes);\n    \n    // Ensure 'issue' is a valid type if no types are configured\n    if (this.validTypes.length === 0) {\n      this.validTypes = ['issue'];\n      logger.debug('No types configured, using default:', this.validTypes);\n    }\n    // Add 'issue' as a default type if not already present\n    else if (!this.validTypes.includes('issue')) {\n      this.validTypes.push('issue');\n      logger.debug('Added issue type:', this.validTypes);\n    }\n    \n    // Initialize plugin service with core states if provided\n    if (this.pluginService) {\n      logger.debug('Registering core types with plugin service:', this.validTypes);\n      // Register core states from config\n      this.pluginService.registerCoreTypes(this.validTypes);\n      this.pluginService.registerCoreActiveStates(this.config.active_states);\n      this.pluginService.registerCoreInactiveReasons(this.config.inactive_reasons);\n      \n      // Get plugin types and combine with our existing types\n      const pluginTypes = this.pluginService.getValidTypes();\n      logger.debug('Plugin types:', pluginTypes);\n      \n      // Combine all types while preserving uniqueness\n      this.validTypes = [...new Set([...this.validTypes, ...pluginTypes])];\n      logger.debug('Final validTypes:', this.validTypes);\n      \n      // Apply plugin patterns\n      this.intentPatterns = this.pluginService.applyPluginIntents(this.intentPatterns);\n    }\n  }\n\n  /**\n   * Get all registered intent patterns, including plugin-provided ones\n   */\n  getIntentPatterns(): IntentPattern[] {\n    return [...this.intentPatterns];\n  }\n\n  isValidState(state: string): boolean {\n    if (!state) return false;\n\n    // Get all valid states including plugin-provided ones\n    const validActiveStates = this.pluginService \n      ? this.pluginService.getValidActiveStates()\n      : this.config.active_states;\n\n    const validInactiveReasons = this.pluginService\n      ? this.pluginService.getValidInactiveReasons()\n      : this.config.inactive_reasons;\n\n    const normalizedState = state.toLowerCase();\n    logger.debug('isValidState - Checking state:', state);\n    logger.debug('isValidState - Valid active states:', validActiveStates);\n    logger.debug('isValidState - Valid inactive reasons:', validInactiveReasons);\n    \n    return validActiveStates.includes(normalizedState) || validInactiveReasons.includes(normalizedState);\n  }\n\n  private isValidInactiveReason(reason: string): boolean {\n    // Get all valid inactive reasons including plugin-provided ones\n    const validReasons = this.pluginService\n      ? this.pluginService.getValidInactiveReasons()\n      : this.config.inactive_reasons;\n\n    return validReasons.includes(reason.toLowerCase());\n  }\n\n  private isValidType(type: string): boolean {\n    if (!type) return false;\n    \n    // Always allow 'issue' type\n    if (type.toLowerCase() === 'issue') return true;\n    \n    // Normalize the type for comparison\n    const normalizedType = type.toLowerCase();\n    logger.debug('isValidType - Checking type:', type);\n    logger.debug('isValidType - Valid types:', this.validTypes);\n    \n    // Check against our combined list of valid types\n    return this.validTypes.some(t => t.toLowerCase() === normalizedType);\n  }\n\n  isActiveState(state: string): boolean {\n    if (!state) return false;\n    \n    // Check if it's an active state from config or plugins\n    const validStates = this.pluginService \n      ? this.pluginService.getValidActiveStates()\n      : this.config.active_states;\n\n    logger.debug('isActiveState - Checking state:', state);\n    logger.debug('isActiveState - Valid states:', validStates);\n    \n    return validStates.includes(state.toLowerCase());\n  }\n\n  isInactiveReason(state: string): boolean {\n    if (!state) return false;\n\n    // Check if it's an inactive reason from config or plugins\n    const validReasons = this.pluginService\n      ? this.pluginService.getValidInactiveReasons()\n      : this.config.inactive_reasons;\n\n    logger.debug('isInactiveReason - Checking state:', state);\n    logger.debug('isInactiveReason - Valid reasons:', validReasons);\n    \n    return validReasons.includes(state.toLowerCase());\n  }\n\n  getCanonicalState(state: string): string {\n    // Get all valid states including plugin-provided ones\n    const validActiveStates = this.pluginService \n      ? this.pluginService.getValidActiveStates()\n      : this.config.active_states;\n\n    const validInactiveReasons = this.pluginService\n      ? this.pluginService.getValidInactiveReasons()\n      : this.config.inactive_reasons;\n\n    // Preserve user's case if it exactly matches a configured state\n    const exactActiveMatch = validActiveStates.find(s => s === state);\n    if (exactActiveMatch) return exactActiveMatch;\n\n    const exactInactiveMatch = validInactiveReasons.find(r => r === state);\n    if (exactInactiveMatch) return exactInactiveMatch;\n\n    // Otherwise find case-insensitive match\n    const activeMatch = validActiveStates.find(s => s.toLowerCase() === state.toLowerCase());\n    if (activeMatch) return activeMatch;\n\n    const inactiveMatch = validInactiveReasons.find(r => r.toLowerCase() === state.toLowerCase());\n    if (inactiveMatch) return inactiveMatch;\n\n    return state; // Let validation catch invalid states\n  }\n\n  getTargetDirForState(state: string, type: string): string {\n    // Ensure we're working with relative paths\n    const rootDir = this.config.issues_dir.replace(/^\\/+/, '');\n    const inboxDir = this.config.inbox_dir.replace(/^\\/+/, '');\n\n    // For active states, use the state directory\n    if (this.isActiveState(state)) {\n      return path.join(rootDir, `_${state}`);\n    }\n\n    // For inactive states, use the type archive directory\n    if (this.isInactiveReason(state)) {\n      return path.join(rootDir, type);\n    }\n\n    // Default to inbox\n    return inboxDir;\n  }\n\n  getTypeArchiveDir(type: string): string {\n    // Ensure we're working with relative paths\n    const rootDir = this.config.issues_dir.replace(/^\\/+/, '');\n    return path.join(rootDir, type);\n  }\n\n  matchState(state: FileState): { matches: boolean; state?: string } {\n    if (!state.pathname || !state.metadata) {\n      return { matches: false };\n    }\n\n    const normalizedPathname = state.pathname.toLowerCase();\n\n    // First check metadata state if present\n    if (state.metadata.state) {\n      const canonicalState = this.getCanonicalState(state.metadata.state);\n      const isActive = this.isActiveState(canonicalState);\n\n      // For active states, check if in correct directory\n      if (isActive) {\n        if (normalizedPathname.includes(`_${canonicalState.toLowerCase()}/`)) {\n          return { matches: true, state: canonicalState };\n        }\n      } else {\n        // For inactive states, check if in type directory\n        if (normalizedPathname.includes(`/${state.metadata.type}/`)) {\n          return { matches: true, state: canonicalState };\n        }\n      }\n      return { matches: false };\n    }\n\n    // If no metadata state, check pathname patterns\n    // Special case for inbox\n    if (normalizedPathname === 'inbox' || normalizedPathname.includes('inbox/')) {\n      return { matches: true, state: 'inbox' };\n    }\n\n    // Check for active states in underscore-prefixed directories\n    for (const activeState of this.config.active_states) {\n      const normalizedState = activeState.toLowerCase();\n      if (normalizedPathname.includes(`_${normalizedState}/`)) {\n        return { matches: true, state: activeState };\n      }\n    }\n\n    // Check for inactive states in type subdirectories\n    for (const inactiveReason of this.config.inactive_reasons) {\n      const normalizedReason = inactiveReason.toLowerCase();\n      if (normalizedPathname.includes(`/${normalizedReason}/`)) {\n        return { matches: true, state: inactiveReason };\n      }\n    }\n\n    return { matches: false };\n  }\n\n  interpretState(state: string): { canonicalState?: string; isActive: boolean } {\n    // Handle inbox state - it's a special case that maps to active with no state\n    if (state.toLowerCase() === 'inbox') {\n      return { canonicalState: undefined, isActive: true };\n    }\n\n    // Get canonical form of state\n    const canonicalState = this.getCanonicalState(state);\n\n    // Check if it's an inactive reason - always set the state and mark as inactive\n    if (this.isInactiveReason(canonicalState)) {\n      return { canonicalState, isActive: false };\n    }\n\n    // Check if it's an active state\n    if (this.isActiveState(canonicalState)) {\n      return { canonicalState, isActive: true };\n    }\n\n    // If it's neither, return the state as is but mark as inactive\n    return { canonicalState, isActive: false };\n  }\n\n  matchesState(metadata: FrontmatterMetadata, stateInfo: { isActive: boolean; canonicalState?: string }): boolean {\n    // Special handling for inbox state\n    if (stateInfo.canonicalState === undefined && stateInfo.isActive) {\n      return metadata.active === true && !metadata.state;\n    }\n\n    // For states, check both the state field and active status\n    return metadata.state === stateInfo.canonicalState && metadata.active === stateInfo.isActive;\n  }\n\n  interpretIntent(state: FileState): InterpretedIntent {\n    const { type } = state.metadata;\n\n    // Handle state-based intents first\n    if (state.metadata.state) {\n      // Special handling for inbox state\n      if (state.metadata.state.toLowerCase() === 'inbox') {\n        const inboxIntent = {\n          targetLocation: {\n            dirname: this.config.inbox_dir || 'inbox',\n            basename: `${type}-${state.metadata.id}.md`\n          },\n          targetMetadata: {\n            ...state.metadata,\n            type,  // Ensure type is set\n            state: undefined,\n            active: true\n          },\n          reason: 'Inbox state specified - normalizing to active with no state'\n        };\n        return inboxIntent;\n      }\n\n      // Get target directory based on state\n      const targetDir = this.getTargetDirForState(state.metadata.state, type);\n      const isActive = this.isActiveState(state.metadata.state);\n\n      return {\n        targetLocation: {\n          dirname: targetDir,\n          basename: `${state.metadata.state}-${type}-${state.metadata.id}.md`\n        },\n        targetMetadata: {\n          ...state.metadata,\n          type,  // Ensure type is set\n          state: state.metadata.state,\n          active: isActive\n        },\n        reason: `File has state '${state.metadata.state}' - moving to appropriate directory`\n      };\n    }\n\n    // For items with no state, check active flag\n    if (state.metadata.active === true) {\n      // Active items with no state go to inbox\n      return {\n        targetLocation: {\n          dirname: this.config.inbox_dir || 'inbox',\n          basename: `${type}-${state.metadata.id}.md`\n        },\n        targetMetadata: {\n          ...state.metadata,\n          type,  // Ensure type is set\n          state: undefined,\n          active: true\n        },\n        reason: 'Active item with no state - moving to inbox'\n      };\n    }\n\n    // For inactive items with no state, move to type directory\n    if (state.metadata.active === false) {\n      const baseDir = this.config.issues_dir || 'issues';\n      return {\n        targetLocation: {\n          dirname: path.join(baseDir, type),\n          basename: `${type}-${state.metadata.id}.md`\n        },\n        targetMetadata: {\n          ...state.metadata,\n          type,  // Ensure type is set\n          active: false,\n          state: undefined\n        },\n        reason: 'Inactive item with no state - moving to type archive'\n      };\n    }\n\n    // Default to inbox for new items\n    return {\n      targetLocation: {\n        dirname: this.config.inbox_dir || 'inbox',\n        basename: `${type}-${state.metadata.id}.md`\n      },\n      targetMetadata: {\n        ...state.metadata,\n        type,  // Ensure type is set\n        state: undefined,\n        active: true\n      },\n      reason: 'New item - moving to inbox'\n    };\n  }\n\n  validateFinalState(state: FileState): ValidationResult {\n    const errors: string[] = [];\n    const warnings: string[] = [];\n\n    // Validate metadata has required fields\n    if (!state.metadata.id) {\n      errors.push('Missing required field: id');\n    }\n    if (!state.metadata.type) {\n      errors.push('Missing required field: type');\n    }\n\n    // Validate type is valid\n    if (state.metadata.type && !this.isValidType(state.metadata.type)) {\n      errors.push(`Invalid type: ${state.metadata.type}`);\n    }\n\n    // Validate state if present\n    if (state.metadata.state && !this.isValidState(state.metadata.state)) {\n      errors.push(`Invalid state: ${state.metadata.state}`);\n    }\n\n    // Validate active status is consistent with state\n    if (state.metadata.state) {\n      const isActive = this.isActiveState(state.metadata.state);\n      if (state.metadata.active === undefined) {\n        warnings.push('Active status not explicitly set - inferring from state');\n      } else if (state.metadata.active !== isActive) {\n        errors.push(`Active status (${state.metadata.active}) does not match state type (${isActive ? 'active' : 'inactive'})`);\n      }\n\n      // Check if file location matches state\n      const targetDir = this.getTargetDirForState(state.metadata.state, state.metadata.type);\n      const currentDir = path.dirname(state.pathname);\n      if (currentDir !== targetDir) {\n        warnings.push('File location does not match state');\n      }\n    }\n\n    return {\n      valid: errors.length === 0,\n      errors,\n      warnings\n    };\n  }\n\n  validateStateTransition(initialState: FileState, targetState: FileState): ValidationResult {\n    const result: ValidationResult = {\n      valid: true,\n      errors: [],\n      warnings: [],\n      guidance: []\n    };\n\n    // First validate the target state\n    const finalStateValidation = this.validateFinalState(targetState);\n    if (finalStateValidation.warnings) {\n      result.warnings!.push(...finalStateValidation.warnings);\n    }\n\n    // Check metadata preservation\n    const preservedFields = ['id', 'type', 'title', 'created'];\n    for (const field of preservedFields) {\n      if (initialState.metadata[field] && initialState.metadata[field] !== targetState.metadata[field]) {\n        result.errors.push(`Field '${field}' must be preserved during state transition`);\n        result.valid = false;\n      }\n    }\n\n    // Check filename pattern\n    const expectedBasename = targetState.metadata.state\n      ? `${targetState.metadata.state}-${targetState.metadata.type}-${targetState.metadata.id}`\n      : `${targetState.metadata.type}-${targetState.metadata.id}`;\n\n    if (targetState.pathname !== expectedBasename) {\n      result.guidance!.push(`Filename '${targetState.pathname}' doesn't match expected pattern '${expectedBasename}' - will be renamed`);\n    }\n\n    return result;\n  }\n\n  validateMetadataAgainstConfig(metadata: FrontmatterMetadata): ValidationResult {\n    const errors: string[] = [];\n    const warnings: string[] = [];\n\n    // Validate type is valid\n    if (metadata.type && !this.isValidType(metadata.type)) {\n      errors.push(`Invalid type: ${metadata.type}`);\n    }\n\n    // Validate state if present\n    if (metadata.state && !this.isValidState(metadata.state)) {\n      errors.push(`Invalid state: ${metadata.state}`);\n    }\n\n    // Validate active status is consistent with state\n    if (metadata.state) {\n      const isActive = this.isActiveState(metadata.state);\n      if (metadata.active === undefined) {\n        warnings.push('Active status not explicitly set - inferring from state');\n      } else if (metadata.active !== isActive) {\n        errors.push(`Active status (${metadata.active}) does not match state type (${isActive ? 'active' : 'inactive'})`);\n      }\n    }\n\n    return {\n      valid: errors.length === 0,\n      errors,\n      warnings\n    };\n  }\n\n  validateMove(sourcePath: string, targetPath: string, metadata: FrontmatterMetadata): ValidationResult {\n    // Get current metadata from source path\n    const sourceState: FileState = {\n      pathname: sourcePath,\n      metadata: { ...metadata }  // Use current metadata as base\n    };\n\n    // Create target state with new metadata\n    const targetState: FileState = {\n      pathname: targetPath,\n      metadata\n    };\n\n    // First validate both states individually\n    const sourceValidation = this.validateFinalState(sourceState);\n    if (!sourceValidation.valid) {\n      return sourceValidation;\n    }\n\n    const targetValidation = this.validateFinalState(targetState);\n    if (!targetValidation.valid) {\n      return targetValidation;\n    }\n\n    // Then validate the transition between them\n    const transitionValidation = this.validateStateTransition(sourceState, targetState);\n    \n    // Combine warnings from all validations\n    const allWarnings = [\n      ...(sourceValidation.warnings || []),\n      ...(targetValidation.warnings || []),\n      ...(transitionValidation.guidance || [])\n    ];\n\n    return {\n      valid: transitionValidation.valid,\n      errors: transitionValidation.errors,\n      warnings: [],  // Add empty warnings array since it's required\n      guidance: allWarnings.length > 0 ? allWarnings : undefined\n    };\n  }\n\n  /**\n   * Clean state transition by removing invalid fields and normalizing values\n   */\n  cleanStateTransition(current: FrontmatterMetadata, next: Partial<FrontmatterMetadata>): FrontmatterMetadata {\n    logger.debug('cleanStateTransition - Current metadata:', current);\n    logger.debug('cleanStateTransition - Next metadata:', next);\n    \n    // Start with current metadata to preserve all fields\n    const result = { ...current };\n\n    // Handle active flag first\n    if (next.active !== undefined) {\n      logger.debug('cleanStateTransition - Setting active:', next.active);\n      result.active = next.active;\n\n      // If setting to active\n      if (next.active === true) {\n        // Clear any existing state when setting to active\n        result.state = undefined;\n      }\n    }\n\n    // Then handle state changes\n    if (next.state !== undefined) {\n      logger.debug('cleanStateTransition - Processing state:', next.state);\n      const state = this.getCanonicalState(next.state);\n      logger.debug('cleanStateTransition - Canonical state:', state);\n      result.state = state;\n      \n      // If transitioning to an inactive reason, always set active to false\n      if (this.isInactiveReason(state)) {\n        logger.debug('cleanStateTransition - State is inactive reason, setting active to false');\n        result.active = false;\n      } else if (this.isActiveState(state)) {\n        logger.debug('cleanStateTransition - State is active state, setting active to true');\n        result.active = true;\n      }\n    }\n\n    // Then process other required fields to ensure they're normalized\n    if (next.type !== undefined) {\n      logger.debug('cleanStateTransition - Setting type:', next.type);\n      result.type = next.type?.toLowerCase();\n    }\n    if (next.id !== undefined) {\n      logger.debug('cleanStateTransition - Setting id:', next.id);\n      result.id = next.id;\n    }\n\n    logger.debug('cleanStateTransition - Final result:', result);\n    return result;\n  }\n\n  /**\n   * Interprets metadata and infers active state\n   */\n  interpretMetadata(metadata: Partial<FrontmatterMetadata>): FrontmatterMetadata {\n    // Create a copy to avoid modifying input\n    const result = { ...metadata } as FrontmatterMetadata;\n\n    // Handle state interpretation\n    if (result.state) {\n      const { canonicalState, isActive } = this.interpretState(result.state);\n      result.state = canonicalState;\n      result.active = isActive;\n    }\n\n    // Handle type interpretation\n    if (!result.type) {\n      // If no type is provided, use 'issue' as default\n      result.type = 'issue';\n    } else {\n      // Normalize type to lowercase\n      result.type = result.type.toLowerCase();\n    }\n\n    // Validate type\n    if (!this.isValidType(result.type)) {\n      throw new Error(`Invalid type: ${result.type}`);\n    }\n\n    return result;\n  }\n\n  /**\n   * Interprets a state transition and returns the necessary metadata updates\n   */\n  interpretStateTransition(targetState: string, options: { reason?: string } = {}): Partial<FrontmatterMetadata> {\n    const stateInfo = this.interpretState(targetState);\n    \n    return {\n      active: stateInfo.isActive,\n      state: stateInfo.canonicalState\n    };\n  }\n\n  // Add a method to get the valid types\n  getValidTypes(): string[] {\n    return this.validTypes;\n  }\n}","import { FileSystemAdapter } from '../utils/file-system-adapter.js';\nimport path from 'path';\nimport { PathnameService } from './pathname-service.js';\n\n/**\n * Centralizes all filesystem operations with atomic guarantees and proper error handling.\n * This service is responsible for:\n * - Atomic file operations\n * - Directory management\n * - File search operations\n * - Temporary file handling\n * - Backup management\n */\nexport class FileService {\n  constructor(\n    private fs: FileSystemAdapter,\n    private pathnameService: PathnameService\n  ) {}\n\n  // Core Operations\n\n  async readFile(filePath: string): Promise<string> {\n    if (!await this.fs.exists(filePath)) {\n      throw new Error(`File not found: ${filePath}`);\n    }\n    return this.fs.readFile(filePath);\n  }\n\n  async writeFile(filePath: string, content: string): Promise<void> {\n    // Use temp file for atomic write\n    return this.withTempFile(filePath, async (tempPath) => {\n      await this.fs.writeFile(tempPath, content);\n    });\n  }\n\n  async moveFile(sourcePath: string, targetPath: string): Promise<void> {\n    // Validate paths\n    if (!await this.fs.exists(sourcePath)) {\n      throw new Error(`Source file not found: ${sourcePath}`);\n    }\n    if (await this.fs.exists(targetPath)) {\n      throw new Error(`Target file already exists: ${targetPath}`);\n    }\n\n    // Ensure target directory exists\n    await this.ensureParentDir(targetPath);\n\n    // Use temp file for atomic move\n    const tempPath = `${targetPath}.tmp`;\n    try {\n      // First copy to temp file\n      await this.fs.move(sourcePath, tempPath);\n      // Then move temp file to target\n      await this.fs.move(tempPath, targetPath);\n    } catch (error) {\n      // Clean up temp file on error\n      try {\n        if (await this.fs.exists(tempPath)) {\n          await this.fs.remove(tempPath);\n        }\n      } catch (cleanupError) {\n        // Ignore cleanup errors\n      }\n      throw error;\n    }\n  }\n\n  async atomicMove(sourcePath: string, targetPath: string, content: string): Promise<void> {\n    // Ensure source file exists\n    if (!await this.fs.exists(sourcePath)) {\n      throw new Error(`File not found: ${sourcePath}`);\n    }\n\n    // Create temp file with new content\n    const tempPath = `${targetPath}.tmp`;\n    try {\n      // Write new content to temp file\n      await this.fs.writeFile(tempPath, content);\n      \n      // Move temp file to target\n      await this.fs.move(tempPath, targetPath);\n      \n      // Remove source file after successful move\n      if (await this.fs.exists(sourcePath)) {\n        await this.fs.remove(sourcePath);\n      }\n    } catch (error) {\n      // Clean up temp file on error\n      try {\n        if (await this.fs.exists(tempPath)) {\n          await this.fs.remove(tempPath);\n        }\n      } catch (cleanupError) {\n        // Ignore cleanup errors\n      }\n      throw error;\n    }\n  }\n\n  // Atomic Operations\n\n  async withTempFile<T>(filePath: string, operation: (tempPath: string) => Promise<T>): Promise<T> {\n    const tempPath = `${filePath}.tmp`;\n    try {\n      const result = await operation(tempPath);\n      if (await this.fs.exists(tempPath)) {\n        await this.fs.move(tempPath, filePath);\n      }\n      return result;\n    } finally {\n      // Always try to cleanup temp file\n      if (await this.fs.exists(tempPath)) {\n        await this.fs.remove(tempPath);\n      }\n    }\n  }\n\n  async withBackup<T>(filePath: string, operation: () => Promise<T>): Promise<T> {\n    const backupPath = `${filePath}.bak`;\n    \n    // Create backup if file exists by copying content\n    if (await this.fs.exists(filePath)) {\n      try {\n        const content = await this.fs.readFile(filePath);\n        await this.fs.writeFile(backupPath, content);\n      } catch (error) {\n        throw new Error('Backup creation failed');\n      }\n    }\n\n    try {\n      // Run the operation\n      const result = await operation();\n      \n      // Remove backup on success\n      if (await this.fs.exists(backupPath)) {\n        try {\n          await this.fs.remove(backupPath);\n        } catch (cleanupError) {\n          // Operation succeeded but cleanup failed\n          // We want to preserve the backup file and throw cleanup error\n          throw new Error('Cleanup failed');\n        }\n      }\n      \n      return result;\n    } catch (error) {\n      const operationError = error as Error;\n      \n      // Don't attempt cleanup if operation failed with cleanup error\n      if (operationError.message === 'Cleanup failed') {\n        throw operationError;\n      }\n      \n      // Restore from backup on error if it exists\n      if (await this.fs.exists(backupPath)) {\n        try {\n          // Read backup content first to ensure we can read it\n          const backupContent = await this.fs.readFile(backupPath);\n          \n          // Remove original file if it exists\n          if (await this.fs.exists(filePath)) {\n            await this.fs.remove(filePath);\n          }\n          \n          // Write backup content back to original file\n          await this.fs.writeFile(filePath, backupContent);\n        } catch (restoreError) {\n          // If restore fails, preserve backup and throw restore error\n          throw new Error('Restore failed');\n        }\n      }\n      \n      // If we get here, either:\n      // 1. There was no backup to restore from\n      // 2. Restore succeeded (but we keep the backup in case cleanup fails)\n      throw operationError;\n    }\n  }\n\n  // Directory Operations\n\n  async ensureDir(dirPath: string): Promise<void> {\n    await this.fs.ensureDir(dirPath);\n  }\n\n  async ensureParentDir(filePath: string): Promise<void> {\n    await this.ensureDir(path.dirname(filePath));\n  }\n\n  // File Search Operations\n\n  async findFile(filename: string, searchPaths: string[]): Promise<string | undefined> {\n    for (const dir of searchPaths) {\n      const filePath = path.join(dir, filename);\n      if (await this.fs.exists(filePath)) {\n        return filePath;\n      }\n    }\n    return undefined;\n  }\n\n  async findFiles(predicate: (filename: string) => boolean, searchPaths: string[]): Promise<string[]> {\n    const results: string[] = [];\n    \n    for (const dir of searchPaths) {\n      if (!await this.fs.exists(dir)) {\n        continue;\n      }\n      \n      const files = await this.fs.readdir(dir);\n      for (const file of files) {\n        if (predicate(file)) {\n          results.push(path.join(dir, file));\n        }\n      }\n    }\n    \n    return results;\n  }\n} ","import { ValidationResult, FrontmatterMetadata } from '../types.js';\nimport { load } from 'js-yaml';\n\nexport class FileFormatValidator {\n  // More permissive regex that allows for extra spaces and newlines\n  private readonly FRONTMATTER_REGEX = /^-{3,}[\\r\\n\\s]+([\\s\\S]*?)[\\r\\n\\s]+-{3,}[\\r\\n\\s]*([\\s\\S]*)$/;\n\n  /**\n   * Validates that a file has the correct format:\n   * - Must be a markdown file\n   * - Must have frontmatter section that can be parsed as YAML\n   * - Must have some content (even if just whitespace)\n   */\n  validateFileFormat(filePath: string, content: string): ValidationResult {\n    const errors: string[] = [];\n\n    // Check file extension - case insensitive\n    if (!filePath.toLowerCase().endsWith('.md')) {\n      errors.push('File must be a markdown file');\n      return { valid: false, errors, warnings: [] };\n    }\n\n    // Check frontmatter structure - more permissive now\n    const match = content.match(this.FRONTMATTER_REGEX);\n    if (!match) {\n      errors.push('File must have frontmatter section marked with ---');\n      return { valid: false, errors, warnings: [] };\n    }\n\n    // Get frontmatter content, allowing for whitespace\n    const frontmatter = match[1].trim();\n    \n    // Validate YAML - only care if it parses\n    try {\n      const parsed = load(frontmatter);\n      if (parsed === null || typeof parsed !== 'object' || Array.isArray(parsed)) {\n        errors.push('Frontmatter must be a valid YAML object');\n        return { valid: false, errors, warnings: [] };\n      }\n    } catch (err) {\n      errors.push('Frontmatter must be valid YAML');\n      return { valid: false, errors, warnings: [] };\n    }\n\n    return {\n      valid: true,\n      errors,\n      warnings: []\n    };\n  }\n\n  /**\n   * Parse frontmatter from content string\n   * Returns null if no valid frontmatter found\n   */\n  parseFrontmatter(content: string): Record<string, any> | null {\n    const match = content.match(this.FRONTMATTER_REGEX);\n    if (!match) {\n      return null;\n    }\n\n    try {\n      const frontmatter = match[1].trim();\n      const parsed = load(frontmatter);\n      if (parsed === null || typeof parsed !== 'object' || Array.isArray(parsed)) {\n        return null;\n      }\n      return parsed as Record<string, any>;\n    } catch (err) {\n      return null;\n    }\n  }\n\n  validateFrontmatterFormat(content: string): ValidationResult {\n    // Check for empty content\n    if (!content.trim()) {\n      return {\n        valid: false,\n        errors: ['Content is empty'],\n        warnings: []\n      };\n    }\n\n    // Check for frontmatter delimiters\n    const match = content.match(/^---\\n([\\s\\S]*?\\n)---\\n/);\n    if (!match) {\n      return {\n        valid: false,\n        errors: ['Content must start with frontmatter delimiters (---)'],\n        warnings: []\n      };\n    }\n\n    try {\n      // Parse YAML content\n      const frontmatter = load(match[1]);\n      if (typeof frontmatter !== 'object' || frontmatter === null) {\n        return {\n          valid: false,\n          errors: ['Frontmatter must be an object'],\n          warnings: []\n        };\n      }\n    } catch (error: any) {\n      return {\n        valid: false,\n        errors: [`Failed to parse frontmatter: ${error.message}`],\n        warnings: []\n      };\n    }\n\n    return {\n      valid: true,\n      errors: [],\n      warnings: []\n    };\n  }\n} ","import { ValidationResult, FrontmatterMetadata } from '../types.js';\n\n/**\n * Validates the format and structure of metadata, not business rules.\n * Only checks that required fields exist and are of the correct type.\n */\nexport class MetadataFormatValidator {\n  /**\n   * Validates that required fields exist and are of the correct type\n   */\n  validateFormat(metadata: any): ValidationResult {\n    const errors: string[] = [];\n\n    // Check if metadata is an object\n    if (typeof metadata !== 'object' || metadata === null) {\n      errors.push('Metadata must be an object');\n      return {\n        valid: false,\n        errors,\n        warnings: []\n      };\n    }\n\n    // Validate required fields\n    const requiredFields = ['id', 'type', 'active'];\n    for (const field of requiredFields) {\n      if (!(field in metadata)) {\n        errors.push(`Missing required field: ${field}`);\n      }\n    }\n\n    // Validate field types and formats\n    if ('id' in metadata) {\n      if (typeof metadata.id !== 'string') {\n        errors.push('Field id must be a string');\n      } else if (!metadata.id.match(/^[a-zA-Z0-9-]+$/)) {\n        errors.push('Field id must contain only alphanumeric characters and hyphens');\n      }\n    }\n\n    if ('type' in metadata) {\n      if (typeof metadata.type !== 'string') {\n        errors.push('Field type must be a string');\n      } else if (!metadata.type.match(/^[a-zA-Z0-9-]+$/)) {\n        errors.push('Field type must contain only alphanumeric characters and hyphens');\n      }\n    }\n\n    if ('active' in metadata && typeof metadata.active !== 'boolean') {\n      errors.push('Field active must be a boolean');\n    }\n\n    // Validate optional state field when present and not undefined\n    if ('state' in metadata && metadata.state !== undefined) {\n      if (typeof metadata.state !== 'string') {\n        errors.push('Field state must be a string');\n      } else if (!metadata.state.match(/^[a-zA-Z0-9-]+$/)) {\n        errors.push('Field state must contain only alphanumeric characters and hyphens');\n      }\n    }\n\n    return {\n      valid: errors.length === 0,\n      errors,\n      warnings: []\n    };\n  }\n\n  /**\n   * Clean metadata by removing invalid fields and normalizing values\n   */\n  cleanMetadata(meta: Partial<FrontmatterMetadata>): FrontmatterMetadata {\n    // Ensure required fields are present\n    if (meta.id === undefined || meta.type === undefined || typeof meta.active !== 'boolean') {\n      throw new Error('Required fields missing: id, type, and active must be present');\n    }\n\n    // Start with required fields\n    const cleaned: FrontmatterMetadata = {\n      id: meta.id,  // Preserve ID case\n      type: meta.type.toLowerCase(),\n      active: meta.active\n    };\n\n    // Add optional fields if present and not undefined\n    if (meta.state !== undefined) {\n      cleaned.state = meta.state.toLowerCase();\n    }\n\n    // Copy any other fields\n    for (const [key, value] of Object.entries(meta)) {\n      if (!['id', 'type', 'active', 'state'].includes(key) && value !== undefined) {\n        cleaned[key] = value;\n      }\n    }\n\n    return cleaned;\n  }\n} ","import { ValidationResult } from '../types.js';\nimport { FileSystemAdapter } from '../utils/file-system-adapter.js';\nimport path from 'path';\n\nexport class FileSystemValidator {\n  constructor(private fs: FileSystemAdapter) {}\n\n  /**\n   * Validates file operations\n   */\n  async validateFileOperation(targetPath: string): Promise<ValidationResult> {\n    const errors: string[] = [];\n\n    // Check if target directory exists\n    const targetDir = path.dirname(targetPath);\n    if (!await this.fs.exists(targetDir)) {\n      errors.push(`Target directory does not exist: ${targetDir}`);\n    }\n\n    // Check if target file already exists\n    if (await this.fs.exists(targetPath)) {\n      errors.push(`Target file already exists: ${targetPath}`);\n    }\n\n    return {\n      valid: errors.length === 0,\n      errors,\n      warnings: []\n    };\n  }\n\n  /**\n   * Validates file paths for move operations\n   */\n  async validateFilePath(sourcePath: string, targetPath: string): Promise<ValidationResult> {\n    const errors: string[] = [];\n\n    // Check if source file exists\n    if (!await this.fs.exists(sourcePath)) {\n      errors.push(`Source file does not exist: ${sourcePath}`);\n    }\n\n    // Check if target directory exists\n    const targetDir = path.dirname(targetPath);\n    if (!await this.fs.exists(targetDir)) {\n      errors.push(`Target directory does not exist: ${targetDir}`);\n    }\n\n    // Check if target file already exists and is different from source\n    if (sourcePath !== targetPath && await this.fs.exists(targetPath)) {\n      errors.push(`Target file already exists: ${targetPath}`);\n    }\n\n    // Check if paths are absolute\n    if (!path.isAbsolute(sourcePath)) {\n      errors.push('Source path must be absolute');\n    }\n    if (!path.isAbsolute(targetPath)) {\n      errors.push('Target path must be absolute');\n    }\n\n    return {\n      valid: errors.length === 0,\n      errors,\n      warnings: []\n    };\n  }\n\n  /**\n   * Validates directory structure\n   */\n  validateDirectoryStructure(dirPath: string): ValidationResult {\n    const errors: string[] = [];\n\n    // Check if path is absolute\n    if (!path.isAbsolute(dirPath)) {\n      errors.push('Directory path must be absolute');\n    }\n\n    // Check for parent directory traversal by looking at raw path components\n    const parts = dirPath.split(path.sep);\n    if (parts.some(part => part === '..')) {\n      errors.push('Directory path cannot contain \"..\"');\n    }\n\n    return {\n      valid: errors.length === 0,\n      errors,\n      warnings: []\n    };\n  }\n\n  async validateFileExists(filePath: string): Promise<ValidationResult> {\n    const errors: string[] = [];\n    \n    if (!(await this.fs.exists(filePath))) {\n      errors.push(`File does not exist: ${filePath}`);\n    }\n\n    return {\n      valid: errors.length === 0,\n      errors,\n      warnings: []\n    };\n  }\n\n  async validateFileDoesNotExist(filePath: string): Promise<ValidationResult> {\n    const errors: string[] = [];\n    \n    if (await this.fs.exists(filePath)) {\n      errors.push(`File already exists: ${filePath}`);\n    }\n\n    return {\n      valid: errors.length === 0,\n      errors,\n      warnings: []\n    };\n  }\n\n  async validateDirectoryExists(dirPath: string): Promise<ValidationResult> {\n    const errors: string[] = [];\n    \n    if (!(await this.fs.exists(dirPath))) {\n      errors.push(`Directory does not exist: ${dirPath}`);\n    } else {\n      const stats = await this.fs.stat(dirPath);\n      if (!stats.isDirectory()) {\n        errors.push(`Path exists but is not a directory: ${dirPath}`);\n      }\n    }\n\n    return {\n      valid: errors.length === 0,\n      errors,\n      warnings: []\n    };\n  }\n} ","import { IntentPattern } from './intent-service.js';\nimport { FrontmatterMetadata } from '../types.js';\nimport { InterpretedIntent } from './intent-service.js';\nimport { logger } from '../utils/logger.js';\nimport { ValidationResult } from '../types.js';\nimport { LLMail } from '../LLMail.js';\nimport { ResolvedConfig } from '../utils/config.js';\n\n/**\n * Context object passed to plugin commands during execution\n */\nexport interface CommandContext {\n  llmail: LLMail;           // Core llmail instance\n  logger: typeof logger;     // llmail's logger\n  config: ResolvedConfig;   // Current config\n  cwd: string;             // Working directory\n  pluginService: PluginService; // Access to plugin service for configuration\n}\n\n/**\n * Describes a command that a plugin may register to extend the llmail CLI.\n */\nexport interface PluginCommand {\n  name: string;\n  description: string;\n  subcommands?: PluginCommand[];\n  options?: Array<{\n    name: string;\n    description?: string;\n    type?: 'boolean' | 'string' | 'number';\n    required?: boolean;\n    default?: any;\n  }>;\n  \n  /** Execute the command with arguments and context */\n  execute: (args: Record<string, any>, context: CommandContext) => Promise<void>;\n  \n  /** Optional hook that runs before command execution. Can modify args. */\n  beforeExecute?: (args: Record<string, any>) => Promise<void | Record<string, any>>;\n  \n  /** Optional hook that runs after successful command execution */\n  afterExecute?: (result: any) => Promise<void>;\n  \n  /** Optional hook that runs when an error occurs. Can transform the error. */\n  onError?: (error: Error, args: Record<string, any>) => Promise<void | Error>;\n}\n\n/**\n * Interface that all plugins must implement\n */\nexport interface Plugin {\n  /** Unique identifier for the plugin */\n  name: string;\n\n  /** Plugin priority - higher numbers run first (default: 0) */\n  priority?: number;\n\n  /** Default configuration for this plugin */\n  defaultConfig?: Record<string, any>;\n\n  /** Optional function to validate plugin configuration */\n  validateConfig?: (config: Record<string, any>) => ValidationResult;\n\n  /** Register new or override existing intent patterns */\n  registerIntents?: (existingPatterns: IntentPattern[]) => IntentPattern[];\n  \n  /** Register additional valid types */\n  registerTypes?: () => string[];\n  \n  /** Register additional valid active states */\n  registerActiveStates?: () => string[];\n  \n  /** Register additional valid inactive reasons */\n  registerInactiveReasons?: () => string[];\n  \n  /** Custom metadata validation hook */\n  validateMetadata?: (metadata: FrontmatterMetadata) => ValidationResult;\n  \n  /** Post-processing hook for interpreted intents */\n  postInterpretIntent?: (intent: InterpretedIntent) => InterpretedIntent;\n\n  /** Optional: Register additional CLI commands for this plugin */\n  registerCommands?: () => PluginCommand[];\n}\n\nexport class PluginService {\n  private plugins: Plugin[] = [];\n  private registeredTypes: Set<string> = new Set();\n  private registeredActiveStates: Set<string> = new Set();\n  private registeredInactiveReasons: Set<string> = new Set();\n  private pluginConfigs: Map<string, any> = new Map();\n  private commands: PluginCommand[] = [];\n\n  /**\n   * Register a new plugin\n   */\n  registerPlugin(plugin: Plugin): void {\n    logger.debug(`Registering plugin: ${plugin.name}`);\n\n    // Check if plugin is already registered\n    if (this.plugins.some(p => p.name === plugin.name)) {\n      throw new Error(\n        `Plugin ${plugin.name} is already registered. ` +\n        `This usually means the plugin is being registered at the wrong level. ` +\n        `Plugins should be registered once at the run level, not per handled object.`\n      );\n    }\n    \n    // Register commands\n    if (plugin.registerCommands) {\n      logger.debug(`Registering commands for plugin ${plugin.name}`);\n      try {\n        const commands = plugin.registerCommands();\n        logger.debug(`Plugin ${plugin.name} registered commands:`, commands);\n        this.commands.push(...commands);\n      } catch (error) {\n        logger.error(`Error registering commands for plugin ${plugin.name}:`, error);\n      }\n    }\n\n    // Register types\n    if (plugin.registerTypes) {\n      logger.debug(`Registering types for plugin ${plugin.name}`);\n      try {\n        const types = plugin.registerTypes();\n        logger.debug(`Plugin ${plugin.name} registered types:`, types);\n        types.forEach(type => this.registeredTypes.add(type));\n      } catch (error) {\n        logger.error(`Error registering types for plugin ${plugin.name}:`, error);\n      }\n    }\n\n    // Register active states\n    if (plugin.registerActiveStates) {\n      logger.debug(`Registering active states for plugin ${plugin.name}`);\n      try {\n        const states = plugin.registerActiveStates();\n        logger.debug(`Plugin ${plugin.name} registered active states:`, states);\n        states.forEach(state => this.registeredActiveStates.add(state));\n      } catch (error) {\n        logger.error(`Error registering active states for plugin ${plugin.name}:`, error);\n      }\n    }\n\n    // Register inactive reasons\n    if (plugin.registerInactiveReasons) {\n      logger.debug(`Registering inactive reasons for plugin ${plugin.name}`);\n      try {\n        const reasons = plugin.registerInactiveReasons();\n        logger.debug(`Plugin ${plugin.name} registered inactive reasons:`, reasons);\n        reasons.forEach(reason => this.registeredInactiveReasons.add(reason));\n      } catch (error) {\n        logger.error(`Error registering inactive reasons for plugin ${plugin.name}:`, error);\n      }\n    }\n\n    // Initialize plugin config with defaults if provided\n    if (plugin.defaultConfig) {\n      logger.debug(`Initializing config for plugin ${plugin.name}`);\n      this.pluginConfigs.set(plugin.name, { ...plugin.defaultConfig });\n    }\n\n    this.plugins.push(plugin);\n    \n    // Sort plugins by priority (highest first)\n    this.plugins.sort((a, b) => (b.priority || 0) - (a.priority || 0));\n\n    logger.info(`Registered plugin: ${plugin.name}`);\n  }\n\n  /**\n   * Get configuration for a specific plugin\n   */\n  getPluginConfig(pluginName: string): any {\n    return this.pluginConfigs.get(pluginName);\n  }\n\n  /**\n   * Set configuration for a specific plugin\n   */\n  setPluginConfig(pluginName: string, config: any): void {\n    const plugin = this.plugins.find(p => p.name === pluginName);\n    if (!plugin) {\n      throw new Error(`Plugin \"${pluginName}\" not found`);\n    }\n\n    // Validate config if plugin has a validator\n    if (plugin.validateConfig) {\n      const result = plugin.validateConfig(config);\n      if (!result.valid) {\n        throw new Error(`Invalid config for plugin ${pluginName}: ${result.errors?.join(', ')}`);\n      }\n    }\n\n    this.pluginConfigs.set(pluginName, config);\n  }\n\n  /**\n   * Get all registered plugins\n   */\n  getPlugins(): Plugin[] {\n    return [...this.plugins];\n  }\n\n  /**\n   * Apply all plugin intent patterns to the existing patterns\n   */\n  applyPluginIntents(existingPatterns: IntentPattern[]): IntentPattern[] {\n    let patterns = [...existingPatterns];\n\n    for (const plugin of this.plugins) {\n      try {\n        if (plugin.registerIntents) {\n          patterns = plugin.registerIntents(patterns);\n        }\n      } catch (error) {\n        logger.error(`Error applying intents from plugin \"${plugin.name}\":`, error);\n      }\n    }\n\n    return patterns;\n  }\n\n  /**\n   * Get all valid types (including plugin-provided ones)\n   */\n  getValidTypes(): string[] {\n    // Start with core types\n    const types = new Set(this.registeredTypes);\n    \n    // Add plugin-provided types\n    for (const plugin of this.plugins) {\n      try {\n        if (plugin.registerTypes) {\n          const pluginTypes = plugin.registerTypes();\n          pluginTypes.forEach(type => types.add(type));\n        }\n      } catch (error) {\n        logger.error(`Error getting types from plugin \"${plugin.name}\":`, error);\n      }\n    }\n\n    // Always ensure 'issue' is included\n    types.add('issue');\n\n    return Array.from(types);\n  }\n\n  /**\n   * Get all valid active states (including plugin-provided ones)\n   */\n  getValidActiveStates(): string[] {\n    const states = new Set(this.registeredActiveStates);\n    \n    for (const plugin of this.plugins) {\n      try {\n        if (plugin.registerActiveStates) {\n          plugin.registerActiveStates().forEach(state => states.add(state));\n        }\n      } catch (error) {\n        logger.error(`Error getting active states from plugin \"${plugin.name}\":`, error);\n      }\n    }\n\n    return Array.from(states);\n  }\n\n  /**\n   * Get all valid inactive reasons (including plugin-provided ones)\n   */\n  getValidInactiveReasons(): string[] {\n    const reasons = new Set(this.registeredInactiveReasons);\n    \n    for (const plugin of this.plugins) {\n      try {\n        if (plugin.registerInactiveReasons) {\n          plugin.registerInactiveReasons().forEach(reason => reasons.add(reason));\n        }\n      } catch (error) {\n        logger.error(`Error getting inactive reasons from plugin \"${plugin.name}\":`, error);\n      }\n    }\n\n    return Array.from(reasons);\n  }\n\n  /**\n   * Get all valid states (both active states and inactive reasons)\n   */\n  getValidStates(): string[] {\n    return [\n      ...this.getValidActiveStates(),\n      ...this.getValidInactiveReasons()\n    ];\n  }\n\n  /**\n   * Run validation hooks from all plugins\n   */\n  validateMetadata(metadata: FrontmatterMetadata): ValidationResult {\n    const result: ValidationResult = {\n      valid: true,\n      errors: [],\n      warnings: []\n    };\n\n    for (const plugin of this.plugins) {\n      try {\n        if (plugin.validateMetadata) {\n          const pluginResult = plugin.validateMetadata(metadata);\n          \n          // Merge warnings\n          if (pluginResult.warnings) {\n            result.warnings.push(...pluginResult.warnings);\n          }\n\n          // If plugin validation fails, merge errors and mark as invalid\n          if (!pluginResult.valid) {\n            result.valid = false;\n            if (pluginResult.errors) {\n              result.errors.push(...pluginResult.errors);\n            }\n          }\n        }\n      } catch (error: any) {\n        logger.error(`Error validating metadata in plugin \"${plugin.name}\":`, error);\n        result.warnings.push(`Plugin ${plugin.name} validation error: ${error.message}`);\n      }\n    }\n\n    return result;\n  }\n\n  /**\n   * Run post-processing hooks from all plugins\n   */\n  processIntent(intent: InterpretedIntent): InterpretedIntent {\n    let processedIntent = { ...intent };\n\n    for (const plugin of this.plugins) {\n      try {\n        if (plugin.postInterpretIntent) {\n          processedIntent = plugin.postInterpretIntent(processedIntent);\n        }\n      } catch (error) {\n        logger.error(`Error processing intent in plugin \"${plugin.name}\":`, error);\n      }\n    }\n\n    return processedIntent;\n  }\n\n  /**\n   * Register core types that plugins can extend\n   */\n  registerCoreTypes(types: string[]): void {\n    // Add each core type to existing types\n    types.forEach(type => this.registeredTypes.add(type));\n  }\n\n  /**\n   * Register core active states that plugins can extend\n   */\n  registerCoreActiveStates(states: string[]): void {\n    states.forEach(state => this.registeredActiveStates.add(state));\n  }\n\n  /**\n   * Register core inactive reasons that plugins can extend\n   */\n  registerCoreInactiveReasons(reasons: string[]): void {\n    reasons.forEach(reason => this.registeredInactiveReasons.add(reason));\n  }\n\n  /**\n   * Collects all plugin commands from every plugin in the order of their priority.\n   */\n  getAllCommands(): PluginCommand[] {\n    logger.debug('Getting all commands:', this.commands);\n    return this.commands;\n  }\n} ","import { customAlphabet } from 'nanoid';\n\n// Only use lowercase alphanumeric characters for IDs\nconst ALPHABET = '0123456789abcdefghijklmnopqrstuvwxyz';\nconst ID_LENGTH = 4;\n\n// Create a nanoid generator with our custom alphabet\nexport const generateId = customAlphabet(ALPHABET, ID_LENGTH); ","import { Plugin } from '../services/plugin-service.js';\nimport { LlmailConfig } from './config.js';\nimport { createRequire } from 'module';\nimport { fileURLToPath } from 'url';\nimport path from 'path';\nimport { logger } from './logger.js';\n\ninterface PluginConfig {\n  name: string;\n  config?: Record<string, any>;\n}\n\n/**\n * Normalize plugin configuration to a consistent format\n */\nfunction normalizePluginConfig(plugins: LlmailConfig['plugins']): PluginConfig[] {\n  if (!plugins) return [];\n\n  if (typeof plugins === 'string') {\n    // Single plugin string\n    return [{ name: plugins }];\n  }\n\n  if (Array.isArray(plugins)) {\n    return plugins.map(plugin => {\n      if (typeof plugin === 'string') {\n        return { name: plugin };\n      }\n      return plugin;\n    });\n  }\n\n  return [];\n}\n\n/**\n * Load a plugin by name\n */\nasync function loadPlugin(name: string): Promise<Plugin> {\n  try {\n    logger.debug(`Loading plugin: ${name}`);\n    // First try dynamic import which works with both real and mocked modules\n    const plugin = await import(name).catch(async (error) => {\n      logger.debug(`Dynamic import failed for ${name}, trying require:`, error);\n      // If dynamic import fails, try require as fallback for CommonJS modules\n      const require = createRequire(import.meta.url);\n      try {\n        const module = require(name);\n        logger.debug(`Required module ${name}:`, module);\n        return module;\n      } catch (requireError) {\n        logger.debug(`Require failed for ${name}:`, requireError);\n        throw requireError;\n      }\n    });\n    \n    logger.debug(`Plugin module loaded: ${name}`, { exports: Object.keys(plugin) });\n    \n    // Handle both default exports and named exports\n    const PluginClass = plugin.default || plugin;\n    logger.debug(`Plugin class found:`, PluginClass);\n    \n    if (typeof PluginClass !== 'function' && !PluginClass.prototype) {\n      logger.debug(`Plugin ${name} exports:`, plugin);\n      throw new Error(`Plugin ${name} must export a class or constructor function`);\n    }\n    \n    const instance = new PluginClass();\n    logger.debug(`Plugin instance created: ${name}`, {\n      commands: instance.registerCommands?.() || [],\n      types: instance.registerTypes?.() || [],\n      activeStates: instance.registerActiveStates?.() || [],\n      inactiveReasons: instance.registerInactiveReasons?.() || []\n    });\n    \n    return instance;\n  } catch (error: any) {\n    logger.error(`Failed to load plugin ${name}:`, error);\n    throw new Error(`Failed to load plugin ${name}: ${error.message}`);\n  }\n}\n\n/**\n * Load and configure plugins from config\n */\nexport async function loadPlugins(config: LlmailConfig): Promise<Plugin[]> {\n  const pluginConfigs = normalizePluginConfig(config.plugins);\n  const plugins: Plugin[] = [];\n\n  logger.debug('Loading plugins from config:', pluginConfigs);\n  for (const pluginConfig of pluginConfigs) {\n    try {\n      const plugin = await loadPlugin(pluginConfig.name);\n      \n      // Apply configuration if provided\n      if (pluginConfig.config && plugin.validateConfig) {\n        const result = plugin.validateConfig(pluginConfig.config);\n        if (!result.valid) {\n          throw new Error(`Invalid config for plugin ${pluginConfig.name}: ${result.errors?.join(', ')}`);\n        }\n      }\n\n      plugins.push(plugin);\n      logger.debug(`Loaded plugin: ${pluginConfig.name}`);\n    } catch (error) {\n      logger.error(`Failed to load plugin ${pluginConfig.name}:`, error);\n      throw error;\n    }\n  }\n\n  return plugins;\n} ","import path from 'path';\nimport { FileSystemAdapter, realFileSystemAdapter } from './utils/file-system-adapter.js';\nimport { loadLlmailConfig, ResolvedConfig } from './utils/config.js';\nimport { IssueService } from './services/issue-service.js';\nimport { PathnameService } from './services/pathname-service.js';\nimport { IntentService } from './services/intent-service.js';\nimport { FileService } from './services/file-service.js';\nimport { FileFormatValidator } from './validation/file-format-validator.js';\nimport { MetadataFormatValidator } from './validation/metadata-format-validator.js';\nimport { FileSystemValidator } from './validation/file-system-validator.js';\nimport { PluginService, Plugin } from './services/plugin-service.js';\nimport { generateId } from './utils/id-generator.js';\nimport { FrontmatterMetadata, OperationResult } from './types.js';\nimport { parseDocSections, rebuildDocSections, ensureTimestamps } from './utils/doc-sections';\nimport { loadPlugins } from './utils/plugin-loader.js';\nimport { logger } from './utils/logger.js';\n\nexport interface LLMailOptions {\n  fs?: FileSystemAdapter;\n  config?: ResolvedConfig;\n  plugins?: Plugin[];\n  rootDir?: string;\n  pluginService?: PluginService;\n}\n\nexport interface MoveOptions {\n  state?: string;\n  type?: string;\n  active?: boolean;\n  inactive?: boolean;\n}\n\nexport interface NewOptions {\n  title?: string;\n  content?: string;\n  state?: string;\n  frontmatter?: Record<string, any>;\n}\n\nexport interface DoneOptions {\n  state?: string;\n  frontmatter?: Record<string, any>;\n}\n\nexport interface SyncOptions {\n  include?: string;\n  exclude?: string;\n  dryRun?: boolean;    // Just show what would change\n  force?: boolean;     // Skip confirmations\n}\n\nexport interface SyncResult {\n  changes: Array<{\n    id: string;\n    from: string;\n    to: string;\n    state: string;\n  }>;\n  errors?: Array<{\n    id: string;\n    error: string;\n  }>;\n}\n\nexport interface Issue {\n  id: string;\n  filePath: string;\n  metadata: FrontmatterMetadata;\n  content?: string;\n}\n\n/**\n * Main class for managing issues and their lifecycle.\n * Provides a high-level API that coordinates between various services.\n */\nexport class LLMail {\n  private fs: FileSystemAdapter;\n  private config?: ResolvedConfig;\n  private issueService!: IssueService;\n  private pathnameService!: PathnameService;\n  private intentService!: IntentService;\n  private fileService!: FileService;\n  private pluginService!: PluginService;\n  private plugins: Plugin[];\n  private rootDir: string;\n\n  constructor(options: LLMailOptions = {}) {\n    this.fs = options.fs || realFileSystemAdapter;\n    this.config = options.config;\n    this.plugins = options.plugins || [];\n    this.rootDir = options.rootDir || process.cwd();\n    if (options.pluginService) {\n      this.pluginService = options.pluginService;\n    }\n  }\n\n  /**\n   * Initialize the LLMail system and all its services\n   */\n  async init(): Promise<void> {\n    // Load config if not already provided\n    if (!this.config) {\n      this.config = await loadLlmailConfig(this.fs, this.rootDir);\n    }\n\n    logger.debug('LLMail init - Config loaded:', this.config);\n\n    // Load plugins from config if not provided in constructor\n    if (this.plugins.length === 0 && this.config.plugins) {\n      logger.debug('LLMail init - Loading plugins from config:', this.config.plugins);\n      try {\n        this.plugins = await loadPlugins(this.config);\n        logger.debug('LLMail init - Plugins loaded:', this.plugins.map(p => p.name));\n      } catch (error) {\n        logger.error('LLMail init - Error loading plugins:', error);\n        throw error;  // Re-throw the error to prevent continuing with invalid plugins\n      }\n    }\n\n    // Initialize plugin service if not provided\n    if (!this.pluginService) {\n      logger.debug('LLMail init - Initializing plugin service');\n      this.pluginService = new PluginService();\n      \n      // Register core types BEFORE registering plugins\n      logger.debug('LLMail init - Registering core types:', this.config.types_list);\n      this.pluginService.registerCoreTypes(this.config.types_list);\n      this.pluginService.registerCoreActiveStates(this.config.active_states);\n      this.pluginService.registerCoreInactiveReasons(this.config.inactive_reasons);\n      \n      // Now register plugins\n      logger.debug('LLMail init - Registering plugins:', this.plugins.map(p => p.name));\n      for (const plugin of this.plugins) {\n        try {\n          logger.debug(`LLMail init - Registering plugin ${plugin.name}`);\n          await this.pluginService.registerPlugin(plugin);\n          logger.debug(`LLMail init - Plugin ${plugin.name} registered successfully`);\n        } catch (error) {\n          logger.error(`LLMail init - Error registering plugin ${plugin.name}:`, error);\n          throw error;  // Re-throw the error to prevent continuing with invalid plugins\n        }\n      }\n    }\n\n    // Initialize core services with plugin service\n    this.intentService = new IntentService(this.config, this.pluginService);\n    this.pathnameService = new PathnameService(this.config, this.intentService);\n    this.fileService = new FileService(this.fs, this.pathnameService);\n\n    // Initialize validators\n    const fileFormatValidator = new FileFormatValidator();\n    const metadataValidator = new MetadataFormatValidator();\n    const fileSystemValidator = new FileSystemValidator(this.fs);\n\n    // Initialize issue service with all dependencies\n    this.issueService = new IssueService(\n      this.pathnameService,\n      this.fs,\n      this.intentService,\n      this.fileService,\n      fileFormatValidator,\n      metadataValidator,\n      fileSystemValidator,\n      this.pluginService\n    );\n\n    // Create required directories\n    const rootDir = this.config.issues_dir.replace(/^\\/+/, '');\n    const inboxDir = this.config.inbox_dir.replace(/^\\/+/, '');\n\n    await this.fs.ensureDir(path.join(this.rootDir, rootDir));\n    await this.fs.ensureDir(path.join(this.rootDir, inboxDir));\n\n    // Create type directories\n    for (const type of this.config.types_list) {\n      await this.fs.ensureDir(path.join(this.rootDir, rootDir, type));\n    }\n\n    // Create state directories\n    for (const state of this.config.active_states) {\n      await this.fs.ensureDir(path.join(this.rootDir, rootDir, `_${state}`));\n    }\n  }\n\n  private ensureInitialized(): void {\n    if (!this.issueService || !this.pathnameService || !this.intentService || !this.fileService) {\n      throw new Error('LLMail not initialized. Call init() first.');\n    }\n  }\n\n  /**\n   * Create a new issue\n   */\n  async new(type: string | undefined, options: NewOptions = {}): Promise<string> {\n    this.ensureInitialized();\n    \n    // If no type is provided, use the default type from intent service\n    const metadata: FrontmatterMetadata = {\n      id: generateId(),\n      type: type || 'issue',  // Default to 'issue' if no type provided\n      active: true,  // new items start active\n      created: new Date().toISOString()\n    };\n\n    // Let intent service interpret and validate the metadata\n    const interpretedMetadata = this.intentService.interpretMetadata(metadata);\n\n    // Merge frontmatter if provided\n    if (options.frontmatter) {\n      Object.assign(interpretedMetadata, options.frontmatter);\n      // Re-assert critical fields that shouldn't be overwritten\n      interpretedMetadata.type = interpretedMetadata.type;  // Keep interpreted type\n      interpretedMetadata.id = interpretedMetadata.id;  // Keep original generated ID\n      interpretedMetadata.active = true;\n      interpretedMetadata.created = interpretedMetadata.created;  // Keep original timestamp\n    }\n\n    if (options.title) {\n      interpretedMetadata.title = options.title;\n    }\n\n    if (options.state) {\n      // Use IntentService to validate the state\n      if (this.intentService.isValidState(options.state)) {\n        interpretedMetadata.state = options.state;\n        interpretedMetadata.active = this.intentService.isActiveState(options.state);\n      } else {\n        throw new Error(`Invalid state: ${options.state}`);\n      }\n    }\n\n    // Get the relative path from IssueService\n    const relativePath = await this.issueService.fileMethods.writeNewFile(interpretedMetadata, options.content || '');\n    \n    // Return just the ID since that's what the API expects\n    return interpretedMetadata.id;\n  }\n\n  /**\n   * Move an issue to a new state or type\n   */\n  async mv(id: string, options: MoveOptions = {}): Promise<OperationResult> {\n    logger.debug('LLMail.mv - Starting move operation');\n    logger.debug('LLMail.mv - Options:', options);\n\n    // Get the issue first to get its file path\n    const issue = await this.getIssueById(id);\n    if (!issue) {\n      throw new Error(`Issue ${id} not found`);\n    }\n\n    logger.debug('LLMail.mv - Initial metadata:', issue.metadata);\n    logger.debug('LLMail.mv - Initial filepath:', issue.filePath);\n\n    // Start with current metadata\n    const updates: Partial<FrontmatterMetadata> = {};\n\n    // Handle type change first if specified\n    if (options.type) {\n      logger.debug('LLMail.mv - Processing type change');\n      if (!this.intentService.getValidTypes().includes(options.type)) {\n        throw new Error(`Invalid type: ${options.type}`);\n      }\n      updates.type = options.type;\n    }\n\n    // Then handle state change if specified\n    if (options.state) {\n      logger.debug('LLMail.mv - Processing state change');\n      if (!this.intentService.isValidState(options.state)) {\n        throw new Error(`Invalid state: ${options.state}`);\n      }\n      updates.state = options.state;\n    }\n\n    // Handle active/inactive flags\n    if (options.active !== undefined) {\n      logger.debug('LLMail.mv - Setting active flag:', options.active);\n      updates.active = options.active;\n      // Clear state when setting active without a specific state\n      if (options.active && !options.state) {\n        logger.debug('LLMail.mv - Clearing state due to active flag');\n        updates.state = undefined;\n      }\n    }\n    if (options.inactive !== undefined) {\n      logger.debug('LLMail.mv - Setting inactive flag:', !options.inactive);\n      updates.active = !options.inactive;\n    }\n\n    logger.debug('LLMail.mv - Final updates:', updates);\n\n    // Apply the updates\n    logger.debug('LLMail.mv - Applying frontmatter updates');\n    await this.updateFrontmatter(id, updates);\n\n    // Sync files to ensure they are in the correct locations\n    logger.debug('LLMail.mv - Starting sync operation');\n    const syncResult = await this.sync({ force: true });\n    logger.debug('LLMail.mv - Sync completed with result:', syncResult);\n\n    // Return success\n    const newIssue = await this.getIssueById(id);\n    logger.debug('LLMail.mv - Final issue state:', newIssue);\n    return {\n      success: true,\n      filepath: newIssue!.filePath\n    };\n  }\n\n  // Add move as an alias for mv for backward compatibility\n  async move(id: string, options: MoveOptions): Promise<OperationResult> {\n    return this.mv(id, options);\n  }\n\n  /**\n   * Get an issue by ID\n   */\n  async getIssueById(id: string): Promise<Issue | undefined> {\n    this.ensureInitialized();\n    \n    const filePath = await this.issueService.fileMethods.findFileById(id);\n    if (!filePath) return undefined;\n\n    const metadata = await this.issueService.frontmatterMethods.getFrontmatterMetadata(filePath);\n    if (!metadata) return undefined;\n\n    const content = await this.fileService.readFile(filePath);\n    \n    return { id, filePath, metadata, content };\n  }\n\n  /**\n   * Update issue frontmatter\n   */\n  async updateFrontmatter(id: string, updates: Partial<FrontmatterMetadata>): Promise<void> {\n    this.ensureInitialized();\n    \n    const issue = await this.getIssueById(id);\n    if (!issue) {\n      throw new Error(`Issue ${id} not found`);\n    }\n\n    await this.issueService.frontmatterMethods.setFrontmatterMetadata(\n      issue.filePath,\n      { ...issue.metadata, ...updates }\n    );\n  }\n\n  /**\n   * Append an update to an issue\n   */\n  async appendUpdate(id: string, content: string, metadata?: Record<string, string>, time: boolean = true): Promise<void> {\n    this.ensureInitialized();\n    \n    await this.issueService.xmlMethods.appendUpdate({\n      id,\n      content,\n      metadata,\n      time\n    });\n  }\n\n  /**\n   * Prepend an update to an issue\n   */\n  async prependUpdate(id: string, content: string, metadata?: Record<string, string>, time: boolean = true): Promise<void> {\n    this.ensureInitialized();\n    \n    await this.issueService.xmlMethods.prependUpdate({\n      id,\n      content,\n      metadata,\n      time\n    });\n  }\n\n  /**\n   * Sync file locations with their metadata\n   */\n  async sync(options: SyncOptions = {}): Promise<SyncResult> {\n    this.ensureInitialized();\n    logger.debug('LLMail.sync - Starting sync operation with options:', options);\n\n    // Get all files by finding files in each state\n    const allFiles = new Set<string>();\n    \n    // Check state directories\n    const allStates = [...this.config!.active_states, ...this.config!.inactive_reasons];\n    logger.debug('LLMail.sync - Checking state directories:', allStates);\n    for (const state of allStates) {\n      const files = await this.issueService.fileMethods.findFilesByState(state);\n      logger.debug(`LLMail.sync - Found files for state ${state}:`, files);\n      files.forEach(f => allFiles.add(f));\n    }\n\n    // Check inbox\n    logger.debug('LLMail.sync - Checking inbox directory');\n    const inboxFiles = await this.issueService.fileMethods.findFilesByState('inbox');\n    logger.debug('LLMail.sync - Found files in inbox:', inboxFiles);\n    inboxFiles.forEach(f => allFiles.add(f));\n\n    // Check type directories\n    logger.debug('LLMail.sync - Checking type directories:', this.config!.types_list);\n    for (const type of this.config!.types_list) {\n      const files = await this.issueService.fileMethods.findFilesByType(type);\n      logger.debug(`LLMail.sync - Found files for type ${type}:`, files);\n      files.forEach(f => allFiles.add(f));\n    }\n\n    // Check root directory\n    logger.debug('LLMail.sync - Checking root directory');\n    const rootFiles = await this.fileService.findFiles(\n      (f) => f.endsWith('.md'),\n      [this.config!.issues_dir]\n    );\n    logger.debug('LLMail.sync - Found files in root:', rootFiles);\n    rootFiles.forEach(f => allFiles.add(f));\n\n    if (allFiles.size === 0) {\n      logger.debug('LLMail.sync - No files found to sync');\n      return { changes: [] };\n    }\n\n    logger.debug('LLMail.sync - Total files to process:', allFiles.size);\n    const changes: Array<{ id: string; from: string; to: string; state: string }> = [];\n    const errors: Array<{ id: string; error: string }> = [];\n\n    for (const filePath of allFiles) {\n      try {\n        logger.debug(`LLMail.sync - Processing file: ${filePath}`);\n        const metadata = await this.issueService.frontmatterMethods.getFrontmatterMetadata(filePath);\n        if (!metadata) {\n          logger.debug(`LLMail.sync - No metadata found for file: ${filePath}`);\n          continue;\n        }\n\n        const targetLocation = this.pathnameService.deriveFileLocation(metadata);\n        const targetPath = path.join(targetLocation.dirname, targetLocation.basename);\n        logger.debug(`LLMail.sync - Target path for file: ${targetPath}`);\n\n        if (targetPath !== filePath) {\n          logger.debug(`LLMail.sync - File needs to be moved from ${filePath} to ${targetPath}`);\n          if (!options.dryRun) {\n            await this.issueService.fileMethods.moveFileWithMetadata(filePath, targetPath, metadata);\n            logger.debug('LLMail.sync - File moved successfully');\n          }\n          changes.push({\n            id: metadata.id,\n            from: filePath,\n            to: targetPath,\n            state: metadata.state ?? ''\n          });\n        } else {\n          logger.debug('LLMail.sync - File is already in correct location');\n        }\n      } catch (err) {\n        const id = path.basename(filePath).split('-')[1]?.split('.')[0] || path.basename(filePath);\n        logger.error(`LLMail.sync - Error processing file ${filePath}:`, err);\n        errors.push({\n          id,\n          error: err instanceof Error ? err.message : String(err)\n        });\n      }\n    }\n\n    logger.debug('LLMail.sync - Sync completed with changes:', changes);\n    if (errors.length > 0) {\n      logger.debug('LLMail.sync - Sync completed with errors:', errors);\n    }\n\n    return {\n      changes,\n      errors: errors.length > 0 ? errors : undefined\n    };\n  }\n\n  /**\n   * Get all valid issue types\n   */\n  async getIssueTypes(): Promise<string[]> {\n    this.ensureInitialized();\n    return this.config!.types_list;\n  }\n\n  /**\n   * Get all valid issue states\n   */\n  async getIssueStates(): Promise<string[]> {\n    this.ensureInitialized();\n    return [...this.config!.active_states, ...this.config!.inactive_reasons];\n  }\n\n  /**\n   * Find issues by type\n   */\n  async findIssuesByType(type: string): Promise<Issue[]> {\n    this.ensureInitialized();\n    \n    if (!this.config!.types_list.includes(type)) {\n      throw new Error(`Invalid type: ${type}`);\n    }\n\n    const files = await this.issueService.fileMethods.findFilesByType(type);\n    const issues: Issue[] = [];\n\n    for (const filePath of files) {\n      const metadata = await this.issueService.frontmatterMethods.getFrontmatterMetadata(filePath);\n      if (metadata) {\n        const content = await this.fileService.readFile(filePath);\n        issues.push({ id: metadata.id, filePath, metadata, content });\n      }\n    }\n\n    return issues;\n  }\n\n  /**\n   * Find issues by state\n   */\n  async findIssuesByState(state: string): Promise<Issue[]> {\n    this.ensureInitialized();\n    \n    if (!this.config!.active_states.includes(state) && !this.config!.inactive_reasons.includes(state)) {\n      throw new Error(`Invalid state: ${state}`);\n    }\n\n    const files = await this.issueService.fileMethods.findFilesByState(state);\n    const issues: Issue[] = [];\n\n    for (const filePath of files) {\n      const metadata = await this.issueService.frontmatterMethods.getFrontmatterMetadata(filePath);\n      if (metadata) {\n        const content = await this.fileService.readFile(filePath);\n        issues.push({ id: metadata.id, filePath, metadata, content });\n      }\n    }\n\n    return issues;\n  }\n\n  async done(id: string, options: DoneOptions = {}): Promise<OperationResult> {\n    this.ensureInitialized();\n\n    const issue = await this.getIssueById(id);\n    if (!issue) {\n      throw new Error(`Issue ${id} not found`);\n    }\n\n    const updates: Partial<FrontmatterMetadata> = {\n      active: false,\n      inactive_timestamp: new Date().toISOString()\n    };\n\n    // If state is provided, validate and use it\n    if (options.state) {\n      if (!this.config!.inactive_reasons.includes(options.state)) {\n        throw new Error(`Invalid inactive reason: ${options.state}`);\n      }\n      updates.state = options.state;\n    }\n\n    // Add any additional frontmatter updates\n    if (options.frontmatter) {\n      Object.assign(updates, options.frontmatter);\n      // Re-assert critical fields that shouldn't be overwritten\n      updates.active = false;\n      updates.inactive_timestamp = updates.inactive_timestamp;\n    }\n\n    // Apply updates\n    await this.updateFrontmatter(id, updates);\n\n    // Sync files to ensure they are in the correct locations\n    await this.sync({ force: true });\n\n    // Return success\n    const newIssue = await this.getIssueById(id);\n    return {\n      success: true,\n      filepath: newIssue!.filePath\n    };\n  }\n\n  /**\n   * Returns only the content section (excludes frontmatter and xml)\n   */\n  async getContent(id: string): Promise<string> {\n    this.ensureInitialized();\n    const filePath = await this.issueService.fileMethods.findFileById(id);\n    if (!filePath) {\n      throw new Error(`File not found for id: ${id}`);\n    }\n\n    const fileString = await this.fileService.readFile(filePath);\n    const sections = parseDocSections(fileString);\n    \n    return sections.content;\n  }\n\n  /**\n   * Overwrites the entire content region (between frontmatter and XML)\n   */\n  async setContent(id: string, newContent: string): Promise<void> {\n    this.ensureInitialized();\n    const filePath = await this.issueService.fileMethods.findFileById(id);\n    if (!filePath) {\n      throw new Error(`File not found for id: ${id}`);\n    }\n\n    const fileString = await this.fileService.readFile(filePath);\n    const sections = parseDocSections(fileString);\n\n    // Update content and timestamps\n    sections.content = newContent;\n    ensureTimestamps(sections.frontmatterObj);\n\n    // Rebuild and write\n    const newString = rebuildDocSections(sections);\n    await this.fileService.writeFile(filePath, newString);\n  }\n\n  /**\n   * Appends text to the end of content region, above the xml region\n   */\n  async appendContent(id: string, content: string): Promise<void> {\n    this.ensureInitialized();\n    const filePath = await this.issueService.fileMethods.findFileById(id);\n    if (!filePath) {\n      throw new Error(`File not found for id: ${id}`);\n    }\n\n    const fileString = await this.fileService.readFile(filePath);\n    const sections = parseDocSections(fileString);\n\n    // Append to content with proper spacing\n    sections.content = sections.content.trimEnd() + (sections.content ? '\\n\\n' : '') + content;\n    ensureTimestamps(sections.frontmatterObj);\n\n    // Rebuild and write\n    const newString = rebuildDocSections(sections);\n    await this.fileService.writeFile(filePath, newString);\n  }\n\n  /**\n   * Prepends text to the start of content region, below the frontmatter\n   */\n  async prependContent(id: string, content: string): Promise<void> {\n    this.ensureInitialized();\n    const filePath = await this.issueService.fileMethods.findFileById(id);\n    if (!filePath) {\n      throw new Error(`File not found for id: ${id}`);\n    }\n\n    const fileString = await this.fileService.readFile(filePath);\n    const sections = parseDocSections(fileString);\n\n    // Prepend to content with proper spacing\n    sections.content = content + (sections.content ? '\\n\\n' : '') + sections.content.trimStart();\n    ensureTimestamps(sections.frontmatterObj);\n\n    // Rebuild and write\n    const newString = rebuildDocSections(sections);\n    await this.fileService.writeFile(filePath, newString);\n  }\n\n  /**\n   * Provides read-access to the plugin service instance,\n   * so that consumers can fetch plugin commands, etc.\n   */\n  getPluginService(): PluginService {\n    this.ensureInitialized();\n    return this.pluginService;\n  }\n\n  /**\n   * Get the current resolved config\n   */\n  getConfig(): ResolvedConfig {\n    if (!this.config) {\n      throw new Error('LLMail not initialized. Call init() first.');\n    }\n    return this.config;\n  }\n\n  /**\n   * Get the intent service instance\n   */\n  getIntentService(): IntentService {\n    this.ensureInitialized();\n    return this.intentService;\n  }\n} ","#!/usr/bin/env node\n\nimport { LLMail } from '../LLMail.js';\nimport { realFileSystemAdapter } from '../utils/file-system-adapter.js';\nimport { loadLlmailConfig } from '../utils/config.js';\nimport { logger } from '../utils/logger.js';\nimport yargs from 'yargs';\nimport { hideBin } from 'yargs/helpers';\n\nasync function main() {\n  const argv = yargs(hideBin(process.argv))\n    .usage('Usage: $0 <id> [options]')\n    .option('state', {\n      alias: 's',\n      type: 'string',\n      description: 'State to mark the item as done (inactive state)'\n    })\n    .option('frontmatter', {\n      alias: 'f',\n      type: 'string',\n      description: 'JSON string representing additional frontmatter updates'\n    })\n    .demandCommand(1, 'You must provide the id of the item to mark as done')\n    .help()\n    .parseSync();\n\n  // Get the positional argument 'id'\n  const id = argv._[0] as string;\n\n  // Build options object for llmail.done()\n  const options: any = {};\n  if (argv.state) {\n    options.state = argv.state;\n  }\n  if (argv.frontmatter) {\n    try {\n      options.frontmatter = JSON.parse(argv.frontmatter);\n    } catch (err) {\n      console.error('Error parsing frontmatter JSON:', err);\n      process.exit(1);\n    }\n  }\n\n  const fsAdapter = realFileSystemAdapter;\n  const rootDir = process.cwd();\n  const configPath = argv.config as string | undefined;\n\n  try {\n    const config = await loadLlmailConfig(fsAdapter, rootDir, configPath);\n    const llmail = new LLMail({ fs: fsAdapter, config });\n    await llmail.init();\n\n    await llmail.done(id, options);\n    logger.success(`Item ${id} marked as done successfully.`);\n  } catch (error) {\n    console.error('Error marking item as done:', error);\n    process.exit(1);\n  }\n}\n\nmain(); "]}