{"version":3,"sources":["../../../src/utils/logger.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/api/mv.ts"],"names":["winston","chalk","load","dump","DEFAULT_SCHEMA","path","_a","timestamp","join"],"mappings":"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","file":"mv.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 { 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 { FileSystemAdapter } from '../../src/utils/file-system-adapter.js';\nimport { IssueService } from '../../src/services/issue-service.js';\nimport { PathnameService } from '../../src/services/pathname-service.js';\nimport { loadLlmailConfig } from '../../src/utils/config.js';\nimport { logger } from '../../src/utils/logger.js';\nimport path from 'path';\nimport { FrontmatterMetadata } from '../../src/types.js';\nimport { ResolvedConfig } from '../../src/utils/config.js';\nimport { IntentService } from '../../src/services/intent-service.js';\nimport { FileService } from '../../src/services/file-service.js';\nimport { FileFormatValidator } from '../../src/validation/file-format-validator.js';\nimport { MetadataFormatValidator } from '../../src/validation/metadata-format-validator.js';\nimport { FileSystemValidator } from '../../src/validation/file-system-validator.js';\nimport { Command } from 'commander';\n\nexport interface MoveOptions {\n  // Core options (from v2)\n  id?: string;\n  active?: boolean;\n  state?: string;\n  target_state?: string;\n  \n  // Path options (from move.ts)\n  sourcePath?: string;\n  targetPath?: string;\n}\n\nexport interface MoveResult {\n  success: boolean;\n  id?: string;\n  path?: string;\n  error?: string;\n  warnings?: string[];\n}\n\n/**\n * Consolidated move implementation that handles:\n * 1. State transitions with metadata updates\n * 2. Path-based file movement\n */\nexport async function move(fs: FileSystemAdapter, options: MoveOptions, config: ResolvedConfig): Promise<MoveResult> {\n  logger.info('Starting move operation...');\n  \n  // Initialize services with provided config\n  const intentService = new IntentService(config);\n  const pathnameService = new PathnameService(config, intentService);\n  const fileService = new FileService(fs, pathnameService);\n  const fileFormatValidator = new FileFormatValidator();\n  const metadataValidator = new MetadataFormatValidator();\n  const fileSystemValidator = new FileSystemValidator(fs);\n  const issueService = new IssueService(\n    pathnameService,\n    fs,\n    intentService,\n    fileService,\n    fileFormatValidator,\n    metadataValidator,\n    fileSystemValidator\n  );\n\n  // Handle path-based movement\n  if (options.sourcePath) {\n    logger.info(`Moving file by path: ${options.sourcePath}`);\n    return handlePathBasedMove(fs, issueService, pathnameService, intentService, options);\n  }\n\n  // Handle ID-based movement\n  if (options.id) {\n    logger.info(`Looking for file with ID: ${options.id}`);\n    return handleIdBasedMove(fs, issueService, pathnameService, intentService, options);\n  }\n\n  return {\n    success: false,\n    error: 'Must specify either state (-s), type (-t), active (-a), or inactive (-i)'\n  };\n}\n\nasync function handleIdBasedMove(\n  fs: FileSystemAdapter,\n  issueService: IssueService,\n  pathnameService: PathnameService,\n  intentService: IntentService,\n  options: MoveOptions\n): Promise<MoveResult> {\n  if (!options.id) {\n    return {\n      success: false,\n      error: 'ID is required for ID-based move'\n    };\n  }\n\n  // Find the file by ID\n  logger.info(`Looking for file with ID: ${options.id}`);\n  const filePath = await issueService.fileMethods.findFileById(options.id);\n  \n  if (!filePath) {\n    logger.error(`File with ID ${options.id} not found`);\n    return {\n      success: false,\n      error: `File with ID ${options.id} not found`\n    };\n  }\n\n  logger.info(`Found file at: ${filePath}`);\n\n  return handleMove(fs, issueService, pathnameService, intentService, {\n    ...options,\n    sourcePath: filePath,\n  });\n}\n\nasync function handlePathBasedMove(\n  fs: FileSystemAdapter,\n  issueService: IssueService,\n  pathnameService: PathnameService,\n  intentService: IntentService,\n  options: MoveOptions\n): Promise<MoveResult> {\n  try {\n    if (!options.sourcePath) {\n      return {\n        success: false,\n        error: 'sourcePath is required for path-based move'\n      };\n    }\n\n    // Convert relative path to absolute path and canonicalize\n    logger.info(`Resolving path: ${options.sourcePath}`);\n    const canonicalPath = path.isAbsolute(options.sourcePath)\n      ? options.sourcePath\n      : path.join(process.cwd(), options.sourcePath);\n    logger.info(`Resolved to: ${canonicalPath}`);\n\n    // Check if source file exists and get metadata\n    const metadataResult = await issueService.frontmatterMethods.getFrontmatterMetadata(canonicalPath);\n    if (!metadataResult) {\n      return {\n        success: false,\n        error: 'No frontmatter found'\n      };\n    }\n\n    // Clean and validate metadata\n    const validation = await issueService.frontmatterMethods.validateMetadata(metadataResult);\n    if (!validation.valid) {\n      return {\n        success: false,\n        error: validation.errors.join(', ')\n      };\n    }\n\n    // Check if target directory exists and is valid\n    const targetPath = options.targetPath || '';\n    const targetExists = await isValidDirectory(fs, targetPath);\n    if (!targetExists) {\n      return {\n        success: false,\n        error: 'Invalid target directory'\n      };\n    }\n\n    try {\n      // Parse the target path to get state information\n      const targetPathInfo = pathnameService.parsePathname(targetPath);\n      logger.info(`Target path info: ${JSON.stringify(targetPathInfo)}`);\n\n      if (!targetPathInfo) {\n        return {\n          success: false,\n          error: 'Invalid target path'\n        };\n      }\n\n      // Update metadata based on target path\n      const updatedMetadata: FrontmatterMetadata = {\n        ...metadataResult,\n        active: targetPathInfo.active ?? metadataResult.active,\n        state: targetPathInfo.state\n      };\n      logger.info(`Updated metadata: ${JSON.stringify(updatedMetadata)}`);\n\n      // Get the target location based on the target path\n      const targetLocation = pathnameService.deriveFileLocation(updatedMetadata);\n      const fullTargetPath = path.join(targetPath, targetLocation.basename);\n\n      // Check if target file already exists\n      const targetFileExists = await fs.exists(fullTargetPath);\n      if (targetFileExists) {\n        return {\n          success: false,\n          error: 'Target file already exists'\n        };\n      }\n\n      // Move the file with updated metadata\n      await issueService.fileMethods.moveFileWithMetadata(canonicalPath, fullTargetPath, updatedMetadata);\n\n      return {\n        success: true,\n        path: fullTargetPath,\n        warnings: validation.warnings\n      };\n    } catch (err) {\n      logger.error(`Move failed: ${err instanceof Error ? err.message : String(err)}`);\n      return {\n        success: false,\n        error: err instanceof Error ? err.message : String(err)\n      };\n    }\n  } catch (err) {\n    logger.error(`Move failed: ${err instanceof Error ? err.message : String(err)}`);\n    return {\n      success: false,\n      error: err instanceof Error ? err.message : String(err)\n    };\n  }\n}\n\nasync function isValidDirectory(fs: FileSystemAdapter, dir: string): Promise<boolean> {\n  if (!dir) return false;\n  try {\n    const stats = await fs.stat(dir);\n    return stats.isDirectory();\n  } catch {\n    return false;\n  }\n}\n\nasync function handleMove(\n  fs: FileSystemAdapter,\n  issueService: IssueService,\n  pathnameService: PathnameService,\n  intentService: IntentService,\n  options: MoveOptions\n): Promise<MoveResult> {\n  const canonicalPath = pathnameService.toCanonicalPath(options.sourcePath!);\n  const metadataResult = await issueService.frontmatterMethods.getFrontmatterMetadata(canonicalPath);\n  \n  if (!metadataResult) {\n    throw new Error(`No metadata found in file ${canonicalPath}`);\n  }\n\n  const validation = await issueService.frontmatterMethods.validateMetadata(metadataResult);\n  if (!validation.valid) {\n    throw new Error(`Invalid metadata: ${validation.errors.join(', ')}`);\n  }\n\n  const updatedMetadata = {\n    ...metadataResult,\n    state: options.target_state,\n    active: options.target_state ? intentService.isActiveState(options.target_state) : metadataResult.active\n  };\n\n  if (!options.targetPath) {\n    throw new Error('Target path is required');\n  }\n\n  const fullTargetPath = pathnameService.toCanonicalPath(options.targetPath);\n  await issueService.fileMethods.moveFileWithMetadata(canonicalPath, fullTargetPath, updatedMetadata);\n\n  return {\n    success: true,\n    path: fullTargetPath,\n    warnings: validation.warnings\n  };\n}\n\nasync function handleStateTransition(\n  fs: FileSystemAdapter,\n  issueService: IssueService,\n  pathnameService: PathnameService,\n  intentService: IntentService,\n  options: MoveOptions\n): Promise<void> {\n  if (!options.sourcePath) {\n    throw new Error('Source path is required');\n  }\n\n  // Get current metadata\n  const metadata = await issueService.frontmatterMethods.getFrontmatterMetadata(options.sourcePath);\n  if (!metadata) {\n    throw new Error('No metadata found');\n  }\n\n  // Update metadata based on options\n  const updates: Partial<FrontmatterMetadata> = {};\n\n  // Handle state transitions\n  if (options.target_state) {\n    // Set metadata.state to the requested new state and update active boolean accordingly\n    if (intentService.isActiveState(options.target_state) || intentService.isInactiveReason(options.target_state)) {\n      updates.state = options.target_state;\n      updates.active = intentService.isActiveState(options.target_state);\n    } else {\n      throw new Error(`Invalid state: ${options.target_state}`);\n    }\n  }\n\n  // Handle active/inactive flags for default sorting when no state is specified\n  if (options.active !== undefined) {\n    updates.active = options.active;\n    // Clear state when explicitly setting active without a state\n    if (!options.target_state) {\n      updates.state = undefined;\n    }\n  }\n\n  // Apply updates\n  const updatedMetadata = { ...metadata, ...updates };\n\n  // Validate the updated metadata\n  const validation = await issueService.frontmatterMethods.validateMetadata(updatedMetadata);\n  if (!validation.valid) {\n    throw new Error(validation.errors.join(', '));\n  }\n\n  // Move the file with updated metadata\n  await issueService.fileMethods.moveFileWithMetadata(options.sourcePath, options.sourcePath, updatedMetadata);\n}\n\nexport class MoveCommand {\n  private fs: FileSystemAdapter;\n  private config: ResolvedConfig;\n\n  constructor(fs: FileSystemAdapter, config: ResolvedConfig) {\n    this.fs = fs;\n    this.config = config;\n  }\n\n  async execute(args: string[]): Promise<MoveResult> {\n    if (args.length < 2) {\n      return {\n        success: false,\n        error: 'Must specify source and target paths'\n      };\n    }\n\n    const [sourcePath, targetPath] = args;\n    return move(this.fs, { sourcePath, targetPath }, this.config);\n  }\n} "]}