85 lines
3.0 KiB
Rust
Raw Normal View History

2021-10-27 18:16:13 +02:00
mod mock_analytics;
// if we are in release mode and the feature analytics was enabled
#[cfg(all(not(debug_assertions), feature = "analytics"))]
mod segment_analytics;
use std::fs;
use std::path::{Path, PathBuf};
use actix_web::HttpRequest;
use once_cell::sync::Lazy;
use platform_dirs::AppDirs;
use serde_json::Value;
use crate::routes::indexes::documents::UpdateDocumentsQuery;
pub use mock_analytics::MockAnalytics;
// if we are in debug mode OR the analytics feature is disabled
// the `SegmentAnalytics` point to the mock instead of the real analytics
#[cfg(any(debug_assertions, not(feature = "analytics")))]
2021-10-28 16:28:41 +02:00
pub type SegmentAnalytics = mock_analytics::MockAnalytics;
#[cfg(any(debug_assertions, not(feature = "analytics")))]
pub type SearchAggregator = mock_analytics::SearchAggregator;
2021-10-27 18:16:13 +02:00
// if we are in release mode and the feature analytics was enabled
// we use the real analytics
#[cfg(all(not(debug_assertions), feature = "analytics"))]
pub type SegmentAnalytics = segment_analytics::SegmentAnalytics;
2021-10-28 16:28:41 +02:00
#[cfg(all(not(debug_assertions), feature = "analytics"))]
pub type SearchAggregator = segment_analytics::SearchAggregator;
2021-10-27 18:16:13 +02:00
/// The Meilisearch config dir:
/// `~/.config/Meilisearch` on *NIX or *BSD.
2021-10-27 18:16:13 +02:00
/// `~/Library/ApplicationSupport` on macOS.
/// `%APPDATA` (= `C:\Users%USERNAME%\AppData\Roaming`) on windows.
static MEILISEARCH_CONFIG_PATH: Lazy<Option<PathBuf>> =
Lazy::new(|| AppDirs::new(Some("Meilisearch"), false).map(|appdir| appdir.config_dir));
2021-10-27 18:16:13 +02:00
fn config_user_id_path(db_path: &Path) -> Option<PathBuf> {
db_path
.canonicalize()
.ok()
.map(|path| {
path.join("instance-uid")
.display()
.to_string()
2022-02-28 13:43:22 +00:00
.replace('/', "-")
2021-10-27 18:16:13 +02:00
})
.zip(MEILISEARCH_CONFIG_PATH.as_ref())
.map(|(filename, config_path)| config_path.join(filename.trim_start_matches('-')))
}
/// Look for the instance-uid in the `data.ms` or in `~/.config/Meilisearch/path-to-db-instance-uid`
2021-10-27 18:16:13 +02:00
fn find_user_id(db_path: &Path) -> Option<String> {
fs::read_to_string(db_path.join("instance-uid"))
.ok()
.or_else(|| fs::read_to_string(&config_user_id_path(db_path)?).ok())
}
pub trait Analytics: Sync + Send {
2021-10-27 18:16:13 +02:00
/// The method used to publish most analytics that do not need to be batched every hours
fn publish(&self, event_name: String, send: Value, request: Option<&HttpRequest>);
2021-10-27 18:16:13 +02:00
/// This method should be called to aggregate a get search
fn get_search(&self, aggregate: SearchAggregator);
2021-10-27 18:16:13 +02:00
2021-10-28 16:28:41 +02:00
/// This method should be called to aggregate a post search
fn post_search(&self, aggregate: SearchAggregator);
2021-10-27 18:16:13 +02:00
2021-10-28 16:28:41 +02:00
// this method should be called to aggregate a add documents request
2021-10-27 18:16:13 +02:00
fn add_documents(
&self,
2021-10-27 18:16:13 +02:00
documents_query: &UpdateDocumentsQuery,
index_creation: bool,
request: &HttpRequest,
);
// this method should be called to batch a update documents request
fn update_documents(
&self,
2021-10-27 18:16:13 +02:00
documents_query: &UpdateDocumentsQuery,
index_creation: bool,
request: &HttpRequest,
);
}