2020-01-31 17:50:28 +08:00
|
|
|
#![allow(clippy::or_fun_call)]
|
|
|
|
|
2019-10-31 22:00:36 +08:00
|
|
|
pub mod data;
|
|
|
|
pub mod error;
|
|
|
|
pub mod helpers;
|
|
|
|
pub mod models;
|
|
|
|
pub mod option;
|
|
|
|
pub mod routes;
|
2020-05-27 01:03:13 +08:00
|
|
|
pub mod analytics;
|
2019-10-31 22:00:36 +08:00
|
|
|
|
2020-04-15 16:51:15 +08:00
|
|
|
use actix_http::Error;
|
|
|
|
use actix_service::ServiceFactory;
|
|
|
|
use actix_web::{dev, web, App};
|
2020-05-22 18:03:57 +08:00
|
|
|
use chrono::Utc;
|
2020-04-15 16:51:15 +08:00
|
|
|
use log::error;
|
2020-05-22 18:03:57 +08:00
|
|
|
|
2020-04-15 16:51:15 +08:00
|
|
|
use meilisearch_core::ProcessedUpdateResult;
|
|
|
|
|
2020-05-27 01:03:13 +08:00
|
|
|
pub use option::Opt;
|
2020-05-22 18:03:57 +08:00
|
|
|
pub use self::data::Data;
|
2020-06-04 00:21:03 +08:00
|
|
|
use self::error::{payload_error_handler, ResponseError};
|
2020-05-22 18:03:57 +08:00
|
|
|
|
2020-04-15 16:51:15 +08:00
|
|
|
pub fn create_app(
|
|
|
|
data: &Data,
|
|
|
|
) -> App<
|
|
|
|
impl ServiceFactory<
|
|
|
|
Config = (),
|
|
|
|
Request = dev::ServiceRequest,
|
|
|
|
Response = dev::ServiceResponse<actix_http::body::Body>,
|
|
|
|
Error = Error,
|
|
|
|
InitError = (),
|
|
|
|
>,
|
|
|
|
actix_http::body::Body,
|
|
|
|
> {
|
|
|
|
App::new()
|
|
|
|
.app_data(web::Data::new(data.clone()))
|
2020-05-07 18:29:18 +08:00
|
|
|
.app_data(
|
|
|
|
web::JsonConfig::default()
|
2020-05-14 23:52:10 +08:00
|
|
|
.limit(data.http_payload_size_limit)
|
2020-05-07 18:29:18 +08:00
|
|
|
.content_type(|_mime| true) // Accept all mime types
|
2020-06-04 00:21:03 +08:00
|
|
|
.error_handler(|err, _req| payload_error_handler(err).into()),
|
|
|
|
)
|
|
|
|
.app_data(
|
|
|
|
web::QueryConfig::default()
|
|
|
|
.error_handler(|err, _req| payload_error_handler(err).into())
|
2020-05-07 18:29:18 +08:00
|
|
|
)
|
2020-04-15 16:51:15 +08:00
|
|
|
.service(routes::load_html)
|
|
|
|
.service(routes::load_css)
|
2020-04-22 23:43:51 +08:00
|
|
|
.configure(routes::document::services)
|
|
|
|
.configure(routes::index::services)
|
|
|
|
.configure(routes::search::services)
|
|
|
|
.configure(routes::setting::services)
|
|
|
|
.configure(routes::stop_words::services)
|
|
|
|
.configure(routes::synonym::services)
|
|
|
|
.configure(routes::health::services)
|
|
|
|
.configure(routes::stats::services)
|
|
|
|
.configure(routes::key::services)
|
2020-04-15 16:51:15 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn index_update_callback(index_uid: &str, data: &Data, status: ProcessedUpdateResult) {
|
|
|
|
if status.error.is_some() {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if let Some(index) = data.db.open_index(&index_uid) {
|
|
|
|
let db = &data.db;
|
2020-05-22 18:03:57 +08:00
|
|
|
let res = db.main_write::<_, _, ResponseError>(|mut writer| {
|
2020-05-22 18:35:23 +08:00
|
|
|
if let Err(e) = data.db.compute_stats(&mut writer, &index_uid) {
|
2020-05-22 18:03:57 +08:00
|
|
|
error!("Impossible to compute stats; {}", e)
|
2020-04-15 16:51:15 +08:00
|
|
|
}
|
|
|
|
|
2020-05-22 18:03:57 +08:00
|
|
|
if let Err(e) = data.db.set_last_update(&mut writer, &Utc::now()) {
|
|
|
|
error!("Impossible to update last_update; {}", e)
|
|
|
|
}
|
2020-04-15 16:51:15 +08:00
|
|
|
|
2020-05-22 18:03:57 +08:00
|
|
|
if let Err(e) = index.main.put_updated_at(&mut writer) {
|
|
|
|
error!("Impossible to update updated_at; {}", e)
|
|
|
|
}
|
|
|
|
Ok(())
|
|
|
|
});
|
|
|
|
match res {
|
|
|
|
Ok(_) => (),
|
|
|
|
Err(e) => error!("{}", e),
|
2020-04-15 16:51:15 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|