// Package main provides email reading functionality for EMLy. // This file contains methods for reading EML, MSG, and PEC email files. package main import ( "emly/backend/utils/mail" ) // ============================================================================= // Email Reading Methods // ============================================================================= // ReadEML reads a standard .eml file and returns the parsed email data. // EML files are MIME-formatted email messages commonly exported from email clients. // // Parameters: // - filePath: Absolute path to the .eml file // // Returns: // - *internal.EmailData: Parsed email with headers, body, and attachments // - error: Any parsing errors func (a *App) ReadEML(filePath string) (*internal.EmailData, error) { return internal.ReadEmlFile(filePath) } // ReadPEC reads a PEC (Posta Elettronica Certificata) .eml file. // PEC emails are Italian certified emails that contain an inner email message // wrapped in a certification envelope with digital signatures. // // This method extracts and returns the inner original email, ignoring the // certification wrapper (daticert.xml and signature files are available as attachments). // // Parameters: // - filePath: Absolute path to the PEC .eml file // // Returns: // - *internal.EmailData: The inner original email content // - error: Any parsing errors func (a *App) ReadPEC(filePath string) (*internal.EmailData, error) { return internal.ReadPecInnerEml(filePath) } // ReadMSG reads a Microsoft Outlook .msg file and returns the email data. // MSG files use the CFB (Compound File Binary) format, which is a proprietary // format used by Microsoft Office applications. // // This method uses an external converter to properly parse the MSG format // and extract headers, body, and attachments. // // Parameters: // - filePath: Absolute path to the .msg file // - useExternalConverter: Whether to use external conversion (currently always true) // // Returns: // - *internal.EmailData: Parsed email data // - error: Any parsing or conversion errors func (a *App) ReadMSG(filePath string, useExternalConverter bool) (*internal.EmailData, error) { // The useExternalConverter parameter is kept for API compatibility // but the implementation always uses the internal MSG reader return internal.ReadMsgFile(filePath) } // ReadMSGOSS reads a .msg file using the open-source parser. // This is an alternative entry point that explicitly uses the OSS implementation. // // Parameters: // - filePath: Absolute path to the .msg file // // Returns: // - *internal.EmailData: Parsed email data // - error: Any parsing errors func (a *App) ReadMSGOSS(filePath string) (*internal.EmailData, error) { return internal.ReadMsgFile(filePath) } // DetectEmailFormat inspects the file's binary content to determine its format, // regardless of the file extension. Returns "eml", "msg", or "unknown". // // Parameters: // - filePath: Absolute path to the file to inspect // // Returns: // - string: Detected format ("eml", "msg", or "unknown") // - error: Any file I/O errors func (a *App) DetectEmailFormat(filePath string) (string, error) { format, err := internal.DetectEmailFormat(filePath) return string(format), err } // ReadAuto automatically detects the email file format from its binary content // and delegates to the appropriate reader (ReadEML/ReadPEC for EML, ReadMSG for MSG). // // Parameters: // - filePath: Absolute path to the email file // // Returns: // - *internal.EmailData: Parsed email data // - error: Any parsing or detection errors func (a *App) ReadAuto(filePath string) (*internal.EmailData, error) { format, err := internal.DetectEmailFormat(filePath) if err != nil { return nil, err } switch format { case internal.FormatMSG: return internal.ReadMsgFile(filePath) default: // FormatEML or FormatUnknown – try PEC first, fall back to plain EML data, err := internal.ReadPecInnerEml(filePath) if err != nil { return internal.ReadEmlFile(filePath) } return data, nil } } // ShowOpenFileDialog displays the system file picker dialog filtered for email files. // This allows users to browse and select .eml or .msg files to open. // // The dialog is configured with filters for: // - EML files (*.eml) // - MSG files (*.msg) // // Returns: // - string: The selected file path, or empty string if cancelled // - error: Any dialog errors func (a *App) ShowOpenFileDialog() (string, error) { return internal.ShowFileDialog(a.ctx) }