atuin/atuin-client/src/history.rs

67 lines
1.5 KiB
Rust
Raw Normal View History

2021-02-13 13:21:49 -07:00
use std::env;
2021-03-19 18:50:31 -06:00
use std::hash::{Hash, Hasher};
2021-02-13 13:21:49 -07:00
use chrono::Utc;
use atuin_common::utils::uuid_v4;
// Any new fields MUST be Optional<>!
#[derive(Debug, Clone, Serialize, Deserialize)]
pub struct History {
2021-02-13 10:02:52 -07:00
pub id: String,
pub timestamp: chrono::DateTime<Utc>,
2021-02-13 10:02:52 -07:00
pub duration: i64,
pub exit: i64,
pub command: String,
pub cwd: String,
2021-02-13 13:21:49 -07:00
pub session: String,
pub hostname: String,
}
impl History {
2021-02-13 13:21:49 -07:00
pub fn new(
timestamp: chrono::DateTime<Utc>,
2021-02-13 13:21:49 -07:00
command: String,
cwd: String,
exit: i64,
duration: i64,
session: Option<String>,
hostname: Option<String>,
2021-02-14 08:15:26 -07:00
) -> Self {
let session = session
.or_else(|| env::var("ATUIN_SESSION").ok())
.unwrap_or_else(uuid_v4);
2021-02-14 10:18:02 -07:00
let hostname =
hostname.unwrap_or_else(|| format!("{}:{}", whoami::hostname(), whoami::username()));
2021-02-13 13:21:49 -07:00
2021-02-14 08:15:26 -07:00
Self {
id: uuid_v4(),
2021-02-13 12:37:00 -07:00
timestamp,
command,
cwd,
2021-02-13 10:02:52 -07:00
exit,
duration,
2021-02-13 13:21:49 -07:00
session,
hostname,
}
}
}
2021-03-19 18:50:31 -06:00
impl PartialEq for History {
// for the sakes of listing unique history only, we do not care about
// anything else
// obviously this does not refer to the *same* item of history, but when
// we only render the command, it looks the same
fn eq(&self, other: &Self) -> bool {
self.command == other.command
}
}
impl Eq for History {}
impl Hash for History {
fn hash<H: Hasher>(&self, state: &mut H) {
self.command.hash(state);
}
}