//! This module provides public models for handling, storing and serializing of search results | |
//! data scraped from the upstream search engines. | |
use serde::{Deserialize, Serialize}; | |
use crate::{config::parser_models::Style, engines::engine_models::EngineError}; | |
/// A named struct to store, serialize and deserializes the individual search result from all the | |
/// scraped and aggregated search results from the upstream search engines. | |
/// | |
/// # Fields | |
/// | |
/// * `title` - The title of the search result. | |
/// * `visiting_url` - The url which is accessed when clicked on it (href url in html in simple | |
/// words). | |
/// * `url` - The url to be displayed below the search result title in html. | |
/// * `description` - The description of the search result. | |
/// * `engine` - The names of the upstream engines from which this results were provided. | |
pub struct SearchResult { | |
pub title: String, | |
pub visiting_url: String, | |
pub url: String, | |
pub description: String, | |
pub engine: Vec<String>, | |
} | |
impl SearchResult { | |
/// Constructs a new `SearchResult` with the given arguments needed for the struct. | |
/// | |
/// # Arguments | |
/// | |
/// * `title` - The title of the search result. | |
/// * `visiting_url` - The url which is accessed when clicked on it | |
/// (href url in html in simple words). | |
/// * `url` - The url to be displayed below the search result title in html. | |
/// * `description` - The description of the search result. | |
/// * `engine` - The names of the upstream engines from which this results were provided. | |
pub fn new( | |
title: String, | |
visiting_url: String, | |
url: String, | |
description: String, | |
engine: Vec<String>, | |
) -> Self { | |
SearchResult { | |
title, | |
visiting_url, | |
url, | |
description, | |
engine, | |
} | |
} | |
} | |
/// A named struct to store the raw scraped search results scraped search results from the | |
/// upstream search engines before aggregating it.It derives the Clone trait which is needed | |
/// to write idiomatic rust using `Iterators`. | |
/// | |
/// # Fields | |
/// | |
/// * `title` - The title of the search result. | |
/// * `visiting_url` - The url which is accessed when clicked on it | |
/// (href url in html in simple words). | |
/// * `description` - The description of the search result. | |
/// * `engine` - The names of the upstream engines from which this results were provided. | |
pub struct RawSearchResult { | |
pub title: String, | |
pub visiting_url: String, | |
pub description: String, | |
pub engine: Vec<String>, | |
} | |
impl RawSearchResult { | |
/// Constructs a new `RawSearchResult` with the given arguments needed for the struct. | |
/// | |
/// # Arguments | |
/// | |
/// * `title` - The title of the search result. | |
/// * `visiting_url` - The url which is accessed when clicked on it | |
/// (href url in html in simple words). | |
/// * `description` - The description of the search result. | |
/// * `engine` - The names of the upstream engines from which this results were provided. | |
pub fn new( | |
title: String, | |
visiting_url: String, | |
description: String, | |
engine: Vec<String>, | |
) -> Self { | |
RawSearchResult { | |
title, | |
visiting_url, | |
description, | |
engine, | |
} | |
} | |
/// A function which adds the engine name provided as a string into a vector of strings. | |
/// | |
/// # Arguments | |
/// | |
/// * `engine` - Takes an engine name provided as a String. | |
pub fn add_engines(&mut self, engine: String) { | |
self.engine.push(engine) | |
} | |
/// A function which returns the engine name stored from the struct as a string. | |
/// | |
/// # Returns | |
/// | |
/// An engine name stored as a string from the struct. | |
pub fn engine(self) -> String { | |
self.engine.get(0).unwrap().to_string() | |
} | |
} | |
pub struct EngineErrorInfo { | |
pub error: String, | |
pub engine: String, | |
} | |
impl EngineErrorInfo { | |
pub fn new(error: &EngineError, engine: String) -> Self { | |
Self { | |
error: match error { | |
EngineError::RequestError => String::from("RequestError"), | |
EngineError::EmptyResultSet => String::from("EmptyResultSet"), | |
EngineError::UnexpectedError => String::from("UnexpectedError"), | |
}, | |
engine, | |
} | |
} | |
} | |
/// A named struct to store, serialize, deserialize the all the search results scraped and | |
/// aggregated from the upstream search engines. | |
/// | |
/// # Fields | |
/// | |
/// * `results` - Stores the individual serializable `SearchResult` struct into a vector of | |
/// `SearchResult` structs. | |
/// * `page_query` - Stores the current pages search query `q` provided in the search url. | |
/// * `style` - Stores the theming options for the website. | |
/// * `engine_errors_info` - Stores the information on which engines failed with their engine name | |
/// and the type of error that caused it. | |
/// * `empty_result_set` - Stores a boolean which indicates that no engines gave a result for the | |
/// given search query. | |
pub struct SearchResults { | |
pub results: Vec<SearchResult>, | |
pub page_query: String, | |
pub style: Style, | |
pub engine_errors_info: Vec<EngineErrorInfo>, | |
} | |
impl SearchResults { | |
/// Constructs a new `SearchResult` with the given arguments needed for the struct. | |
/// | |
/// # Arguments | |
/// | |
/// * `results` - Takes an argument of individual serializable `SearchResult` struct | |
/// and stores it into a vector of `SearchResult` structs. | |
/// * `page_query` - Takes an argument of current page`s search query `q` provided in | |
/// the search url. | |
/// * `empty_result_set` - Takes a boolean which indicates that no engines gave a result for the | |
/// given search query. | |
pub fn new( | |
results: Vec<SearchResult>, | |
page_query: String, | |
engine_errors_info: Vec<EngineErrorInfo>, | |
) -> Self { | |
SearchResults { | |
results, | |
page_query, | |
style: Style::new("".to_string(), "".to_string()), | |
engine_errors_info, | |
} | |
} | |
/// A setter function to add website style to the return search results. | |
pub fn add_style(&mut self, style: Style) { | |
self.style = style; | |
} | |
} | |