chore: add AppLogs
This commit is contained in:
parent
4726295370
commit
c1ad9c26da
92
app_env/src/applogs.rs
Normal file
92
app_env/src/applogs.rs
Normal file
@ -0,0 +1,92 @@
|
|||||||
|
//
|
||||||
|
// Copyright 2021, Jesús Pérez Lorenzo
|
||||||
|
//
|
||||||
|
//use std::collections::HashMap;
|
||||||
|
use serde::{Serialize,Deserialize,};
|
||||||
|
use anyhow::{Result};
|
||||||
|
use std::{fs}; //,io};
|
||||||
|
use std::fs::OpenOptions;
|
||||||
|
use std::io::{Write};
|
||||||
|
use std::path::Path;
|
||||||
|
|
||||||
|
// use crate::{
|
||||||
|
// config::{Config,WebServer},
|
||||||
|
// module::Module,
|
||||||
|
// appinfo::AppInfo,
|
||||||
|
// };
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, Serialize, Deserialize)]
|
||||||
|
pub struct AppLogs {
|
||||||
|
pub id: String,
|
||||||
|
pub when: String,
|
||||||
|
pub name: String,
|
||||||
|
pub source: String,
|
||||||
|
pub target: String,
|
||||||
|
pub state: String,
|
||||||
|
pub msg: String
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Default for AppLogs {
|
||||||
|
fn default() -> Self {
|
||||||
|
Self {
|
||||||
|
id: String::from(""),
|
||||||
|
name: String::from(""),
|
||||||
|
when: format!("{}", chrono::Utc::now().timestamp()),
|
||||||
|
source: String::from(""),
|
||||||
|
target: String::from(""),
|
||||||
|
state: String::from(""),
|
||||||
|
msg: String::from(""),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
impl AppLogs {
|
||||||
|
pub async fn write_applogs_entry(&self, output_path: &str) -> Result<()> {
|
||||||
|
let mut out = serde_json::to_string(&self).unwrap_or_else(|e|{
|
||||||
|
eprintln!("Error write to applogs: {}",e);
|
||||||
|
String::from("")
|
||||||
|
});
|
||||||
|
if out.is_empty() {
|
||||||
|
return Ok(());
|
||||||
|
}
|
||||||
|
out = format!("{},\n",&out);
|
||||||
|
if Path::new(&output_path).exists() {
|
||||||
|
let mut file = OpenOptions::new().append(true).open(&output_path)?;
|
||||||
|
// out = out.replace("/", "/");
|
||||||
|
file.write(out.as_bytes())?;
|
||||||
|
} else {
|
||||||
|
let mut file = OpenOptions::new().write(true).create(true).open(&output_path)?;
|
||||||
|
file.write_all(out.as_bytes())?;
|
||||||
|
}
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
pub async fn load_applogs_entries(source_path: &str) -> Result<Vec<AppLogs>> {
|
||||||
|
let applogs: Vec<AppLogs>;
|
||||||
|
if Path::new(&source_path).exists() {
|
||||||
|
let content = fs::read_to_string(&source_path).unwrap_or_else(|e| {
|
||||||
|
println!("Failed to read json 'applogs_path' from {}: {}", &source_path,e);
|
||||||
|
String::from("")
|
||||||
|
});
|
||||||
|
if content.is_empty() {
|
||||||
|
return Ok(Vec::new());
|
||||||
|
}
|
||||||
|
applogs = serde_json::from_str(&content).unwrap_or_else(|e|{
|
||||||
|
eprintln!("Error reading applogs {}: {}",&source_path,e);
|
||||||
|
Vec::new()
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
applogs = Vec::new();
|
||||||
|
}
|
||||||
|
Ok(applogs)
|
||||||
|
}
|
||||||
|
pub fn get_applogs_entries(entries: Vec<AppLogs>, criteria: AppLogs) -> Vec<AppLogs> {
|
||||||
|
entries.iter().filter(|entry|
|
||||||
|
(!criteria.id.is_empty() && entry.id == criteria.id)
|
||||||
|
|| (!criteria.name.is_empty() && entry.name == criteria.name)
|
||||||
|
|| (!criteria.state.is_empty() && entry.state.contains(&criteria.state))
|
||||||
|
|| (!criteria.source.is_empty() && entry.source.contains(&criteria.source))
|
||||||
|
|| (!criteria.target.is_empty() && entry.target.contains(&criteria.target))
|
||||||
|
|| (!criteria.when.is_empty() && entry.when.contains(&criteria.when))
|
||||||
|
|| (!criteria.msg.is_empty() && entry.msg.contains(&criteria.msg))
|
||||||
|
).map(|entry|entry.to_owned()).collect()
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user