kelora 1.5.0

A command-line log analysis tool with embedded Rhai scripting
Documentation
use crate::event::Event;
use crate::pipeline::{EventParser, PrefixExtractor};
use anyhow::Result;

/// Wrapper parser that extracts prefix before parsing and adds it to the event
pub struct PrefixExtractingParser {
    inner: Box<dyn EventParser>,
    prefix_extractor: Option<PrefixExtractor>,
}

impl PrefixExtractingParser {
    pub fn new(inner: Box<dyn EventParser>, prefix_extractor: Option<PrefixExtractor>) -> Self {
        Self {
            inner,
            prefix_extractor,
        }
    }
}

impl EventParser for PrefixExtractingParser {
    fn parse(&self, line: &str) -> Result<Event> {
        let (modified_line, extracted_prefix) = if let Some(ref extractor) = self.prefix_extractor {
            extractor.extract_prefix(line)
        } else {
            (line.to_string(), None)
        };

        // Parse the line with the prefix removed
        let mut event = self.inner.parse(&modified_line)?;

        // Add the extracted prefix to the event if we have one
        if let Some(ref extractor) = self.prefix_extractor {
            extractor.add_prefix_to_event(&mut event, extracted_prefix);
        }

        Ok(event)
    }
}

#[cfg(test)]
mod tests {
    use super::*;
    use crate::parsers::LineParser;

    #[test]
    fn test_prefix_extracting_parser() {
        let base_parser = Box::new(LineParser::new());
        let extractor = PrefixExtractor::new("src".to_string(), "|".to_string());
        let parser = PrefixExtractingParser::new(base_parser, Some(extractor));

        let result = parser.parse("web_1 | Test message").unwrap();

        assert_eq!(
            result
                .fields
                .get("line")
                .unwrap()
                .clone()
                .into_string()
                .unwrap(),
            "Test message"
        );
        assert_eq!(
            result
                .fields
                .get("src")
                .unwrap()
                .clone()
                .into_string()
                .unwrap(),
            "web_1"
        );
    }

    #[test]
    fn test_prefix_extracting_parser_no_prefix() {
        let base_parser = Box::new(LineParser::new());
        let extractor = PrefixExtractor::new("src".to_string(), "|".to_string());
        let parser = PrefixExtractingParser::new(base_parser, Some(extractor));

        let result = parser.parse("Just a normal message").unwrap();

        assert_eq!(
            result
                .fields
                .get("line")
                .unwrap()
                .clone()
                .into_string()
                .unwrap(),
            "Just a normal message"
        );
        assert!(result.fields.get("src").is_none());
    }

    #[test]
    fn test_prefix_extracting_parser_no_extractor() {
        let base_parser = Box::new(LineParser::new());
        let parser = PrefixExtractingParser::new(base_parser, None);

        let result = parser.parse("web_1 | Test message").unwrap();

        assert_eq!(
            result
                .fields
                .get("line")
                .unwrap()
                .clone()
                .into_string()
                .unwrap(),
            "web_1 | Test message"
        );
        assert!(result.fields.get("src").is_none());
    }
}