apimock-routing 5.1.1

Routing model for apimock: rule sets, request matching, and read-only views for GUI tooling.
Documentation
use console::style;
use serde::Deserialize;

use std::path::Path;

#[derive(Clone, Default, Deserialize, Debug)]
pub struct Prefix {
    #[serde(rename = "url_path")]
    pub url_path_prefix: Option<String>,
    #[serde(rename = "respond_dir")]
    pub respond_dir_prefix: Option<String>,
}

impl Prefix {
    /// validate
    pub fn validate(&self, rule_set_idx: usize) -> bool {
        let respond_dir_prefix_validate =
            if let Some(respond_dir_prefix) = self.respond_dir_prefix.as_ref() {
                let exists = Path::new(respond_dir_prefix.as_str()).exists();
                if !exists {
                    log::error!(
                        "{} of prefix (rule set #{}):\n`{}`",
                        style("directory not found").red(),
                        rule_set_idx,
                        self.respond_dir_prefix.clone().unwrap().as_str()
                    );
                }
                exists
            } else {
                true
            };
        respond_dir_prefix_validate
    }
}

impl std::fmt::Display for Prefix {
    fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
        let has_written = self.url_path_prefix.is_some() || self.respond_dir_prefix.is_some();

        if self.url_path_prefix.is_some() {
            let _ = writeln!(
                f,
                "[url_path_prefix] {}",
                style(self.url_path_prefix.as_ref().unwrap()).magenta()
            );
        }

        if self.respond_dir_prefix.is_some() {
            let _ = writeln!(
                f,
                "[respond_dir_prefix] {}",
                style(self.respond_dir_prefix.clone().unwrap_or_default().as_str()).magenta()
            );
        }

        if has_written {
            let _ = writeln!(f, "");
        }

        Ok(())
    }
}