Reorganizing files
This commit is contained in:
parent
1c4077ffc3
commit
883a0669fe
11 changed files with 105 additions and 45 deletions
|
|
@ -1,4 +1,2 @@
|
|||
pub mod unified;
|
||||
pub use unified::model::unify_data;
|
||||
pub mod heartbeat;
|
||||
pub mod status_page;
|
||||
|
|
|
|||
|
|
@ -1 +0,0 @@
|
|||
pub mod model;
|
||||
|
|
@ -1,47 +0,0 @@
|
|||
use crate::data::heartbeat;
|
||||
use crate::data::heartbeat::model::{HeartbeatEntry, HeartbeatResponse, UptimeData};
|
||||
use crate::data::status_page::model::{MonitorInfo, StatusPageResponse};
|
||||
|
||||
#[derive(Debug, Clone)]
|
||||
pub struct UnifiedMonitorData {
|
||||
pub monitor_info: MonitorInfo,
|
||||
pub heartbeats: Vec<HeartbeatEntry>,
|
||||
pub uptime_data: Option<UptimeData>,
|
||||
}
|
||||
|
||||
#[derive(Debug, Clone)]
|
||||
pub struct UnifiedData {
|
||||
pub status_page_title: String,
|
||||
pub status_page_description: Option<String>,
|
||||
pub monitors: Vec<UnifiedMonitorData>,
|
||||
}
|
||||
pub fn unify_data(status_page: &StatusPageResponse, heartbeat: &HeartbeatResponse) -> UnifiedData {
|
||||
let mut monitors = Vec::new();
|
||||
|
||||
for group in &status_page.public_group_list {
|
||||
for monitor_info in &group.monitor_list {
|
||||
let uptime_data = heartbeat.get_uptime(monitor_info.id, 24).cloned();
|
||||
|
||||
let heartbeats = heartbeat
|
||||
.monitors
|
||||
.iter()
|
||||
.find(|m| m.monitor_id == monitor_info.id)
|
||||
.map(|m| m.heartbeats.clone())
|
||||
.unwrap_or_else(Vec::new);
|
||||
|
||||
monitors.push(UnifiedMonitorData {
|
||||
monitor_info: monitor_info.clone(),
|
||||
heartbeats,
|
||||
uptime_data,
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
monitors.sort_by_key(|m| m.monitor_info.id);
|
||||
|
||||
UnifiedData {
|
||||
status_page_title: status_page.config.title.clone(),
|
||||
status_page_description: status_page.config.description.clone(),
|
||||
monitors,
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue