mirror of
https://github.com/rosenpass/rosenpass.git
synced 2025-12-18 21:34:37 +03:00
Compare commits
1 Commits
dev/karo/t
...
dev/improv
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
96bc5bfb2e |
7
Cargo.lock
generated
7
Cargo.lock
generated
@@ -1176,6 +1176,13 @@ dependencies = [
|
|||||||
"thiserror",
|
"thiserror",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "rosenpass-log"
|
||||||
|
version = "0.1.0"
|
||||||
|
dependencies = [
|
||||||
|
"log",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "rosenpass-oqs"
|
name = "rosenpass-oqs"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
|
|||||||
@@ -13,6 +13,7 @@ members = [
|
|||||||
"fuzz",
|
"fuzz",
|
||||||
"secret-memory",
|
"secret-memory",
|
||||||
"lenses",
|
"lenses",
|
||||||
|
"rosenpass-log",
|
||||||
]
|
]
|
||||||
|
|
||||||
default-members = [
|
default-members = [
|
||||||
|
|||||||
9
rosenpass-log/Cargo.toml
Normal file
9
rosenpass-log/Cargo.toml
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
[package]
|
||||||
|
name = "rosenpass-log"
|
||||||
|
version = "0.1.0"
|
||||||
|
edition = "2021"
|
||||||
|
|
||||||
|
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
||||||
|
|
||||||
|
[dependencies]
|
||||||
|
log.workspace = true
|
||||||
110
rosenpass-log/src/lib.rs
Normal file
110
rosenpass-log/src/lib.rs
Normal file
@@ -0,0 +1,110 @@
|
|||||||
|
#![allow(unused_macros)]
|
||||||
|
/// Whenever a log event occurs, the cause of the event must be decided on. This cause will then
|
||||||
|
/// be used to decide, if an actual log event is to be cause. The goal is to prevent especially
|
||||||
|
/// external, unautherized entities from causing excessive loggin, which otherwise might open the
|
||||||
|
/// door to MITM attacks
|
||||||
|
pub enum Cause {
|
||||||
|
/// An unauthorized entitiy triggered this event via Network
|
||||||
|
///
|
||||||
|
/// Example: a InitHello message in the rosenpass protocol
|
||||||
|
UnauthorizedNetwork,
|
||||||
|
|
||||||
|
/// An authorized entitity triggered this event via Network
|
||||||
|
///
|
||||||
|
/// Example: a handshake was succesful (which asserts the peer is authorized)
|
||||||
|
AuthorizedNetwork,
|
||||||
|
|
||||||
|
/// A local entity like rosenpassctl triggered this event
|
||||||
|
///
|
||||||
|
/// Example: the broker adds a new peer
|
||||||
|
LocalNetwork,
|
||||||
|
|
||||||
|
/// The user caused this event
|
||||||
|
///
|
||||||
|
/// Examples:
|
||||||
|
/// - The process was started
|
||||||
|
/// - Ctrl+C was used to send sig SIGINT
|
||||||
|
User,
|
||||||
|
|
||||||
|
/// The developer wanted this in the log!
|
||||||
|
Developer,
|
||||||
|
}
|
||||||
|
|
||||||
|
// Rational: All events are to be displayed if trace level debugging is configured
|
||||||
|
macro_rules! trace {
|
||||||
|
($cause:expr, $($tail:tt)* ) => {{
|
||||||
|
use crate::Cause::*;
|
||||||
|
match $cause {
|
||||||
|
UnauthorizedNetwork | AuthorizedNetwork | LocalNetwork | User | Developer => {
|
||||||
|
::log::trace!($($tail)*);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Rational: All events are to be displayed if debug level debugging is configured
|
||||||
|
macro_rules! debug {
|
||||||
|
($cause:expr, $($tail:tt)* ) => {{
|
||||||
|
use crate::Cause::*;
|
||||||
|
match $cause {
|
||||||
|
UnauthorizedNetwork | AuthorizedNetwork | LocalNetwork | User | Developer => {
|
||||||
|
::log::debug!($($tail)*);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Rational: Only authorized causes shall be able to emit info messages
|
||||||
|
macro_rules! info {
|
||||||
|
($cause:expr, $($tail:tt)* ) => {{
|
||||||
|
use crate::Cause::*;
|
||||||
|
match $cause {
|
||||||
|
UnauthorizedNetwork => {},
|
||||||
|
AuthorizedNetwork | LocalNetwork | User | Developer => {
|
||||||
|
::log::info!($($tail)*);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Rational: Only authorized causes shall be able to emit info messages
|
||||||
|
macro_rules! warn {
|
||||||
|
($cause:expr, $($tail:tt)* ) => {{
|
||||||
|
use crate::Cause::*;
|
||||||
|
match $cause {
|
||||||
|
UnauthorizedNetwork => {},
|
||||||
|
AuthorizedNetwork | LocalNetwork | User | Developer =>{
|
||||||
|
::log::warn!($($tail)*);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Rational: Only local sources shall be able to cause errors to be displayed
|
||||||
|
macro_rules! error {
|
||||||
|
($cause:expr, $($tail:tt)* ) => {{
|
||||||
|
use crate::Cause::*;
|
||||||
|
match $cause {
|
||||||
|
UnauthorizedNetwork | AuthorizedNetwork => {},
|
||||||
|
LocalNetwork | User | Developer => {
|
||||||
|
::log::error!($($tail)*);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use super::*;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn expand_all_macros() {
|
||||||
|
use Cause::*;
|
||||||
|
|
||||||
|
trace!(UnauthorizedNetwork, "beep");
|
||||||
|
debug!(UnauthorizedNetwork, "boop");
|
||||||
|
info!(LocalNetwork, "tock");
|
||||||
|
warn!(LocalNetwork, "möp");
|
||||||
|
error!(User, "knirsch");
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user