mirror of
https://github.com/element-hq/element-android
synced 2024-12-19 15:58:27 +03:00
rust: Add support to forward rust logs to the kotlin side
This commit is contained in:
parent
3ddbe7e69b
commit
4589b882c0
3 changed files with 63 additions and 7 deletions
|
@ -11,10 +11,13 @@ name = "matrix_crypto"
|
|||
[dependencies]
|
||||
matrix-sdk-common = { git = "https://github.com/matrix-org/matrix-rust-sdk/"}
|
||||
futures = { version = "0.3.12", default_features = false, features = ["executor"] }
|
||||
tokio = { version = "1.1.1", default_features = false, features = ["rt-multi-thread", "time"] }
|
||||
serde_json = "1.0.61"
|
||||
tokio = { version = "1.2.0", default_features = false, features = ["rt-multi-thread", "time"] }
|
||||
serde_json = "1.0.62"
|
||||
thiserror = "1.0.23"
|
||||
http = "0.2.3"
|
||||
tracing = "0.1.23"
|
||||
tracing-subscriber = "0.2.15"
|
||||
once_cell = "1.5.2"
|
||||
|
||||
[dependencies.matrix-sdk-crypto]
|
||||
git = "https://github.com/matrix-org/matrix-rust-sdk/"
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
use std::{
|
||||
collections::{BTreeMap, HashMap},
|
||||
convert::TryFrom,
|
||||
sync::{Arc, Mutex},
|
||||
time::Duration,
|
||||
};
|
||||
|
||||
|
@ -25,6 +26,55 @@ use matrix_sdk_crypto::{
|
|||
store::CryptoStoreError as InnerStoreError, IncomingResponse, OlmError,
|
||||
OlmMachine as InnerMachine, OutgoingRequest, ToDeviceRequest,
|
||||
};
|
||||
use tracing_subscriber::{fmt::MakeWriter, EnvFilter};
|
||||
|
||||
pub trait Logger: Send {
|
||||
fn log(&self, log_line: String);
|
||||
}
|
||||
|
||||
impl std::io::Write for LoggerWrapper {
|
||||
fn write(&mut self, buf: &[u8]) -> std::io::Result<usize> {
|
||||
let data = String::from_utf8_lossy(buf).to_string();
|
||||
self.inner.lock().unwrap().log(data);
|
||||
|
||||
Ok(buf.len())
|
||||
}
|
||||
|
||||
fn flush(&mut self) -> std::io::Result<()> {
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
|
||||
impl MakeWriter for LoggerWrapper {
|
||||
type Writer = LoggerWrapper;
|
||||
|
||||
fn make_writer(&self) -> Self::Writer {
|
||||
self.clone()
|
||||
}
|
||||
}
|
||||
|
||||
#[derive(Clone)]
|
||||
pub struct LoggerWrapper {
|
||||
inner: Arc<Mutex<Box<dyn Logger>>>,
|
||||
}
|
||||
|
||||
pub fn set_logger(logger: Box<dyn Logger>) {
|
||||
let logger = LoggerWrapper {
|
||||
inner: Arc::new(Mutex::new(logger)),
|
||||
};
|
||||
|
||||
let filter = EnvFilter::from_default_env().add_directive(
|
||||
"matrix_sdk_crypto=trace"
|
||||
.parse()
|
||||
.expect("Can't parse logging filter directive"),
|
||||
);
|
||||
|
||||
let _ = tracing_subscriber::fmt()
|
||||
.with_writer(logger)
|
||||
.with_env_filter(filter)
|
||||
.without_time()
|
||||
.try_init();
|
||||
}
|
||||
|
||||
pub struct OlmMachine {
|
||||
inner: InnerMachine,
|
||||
|
@ -205,10 +255,7 @@ impl OlmMachine {
|
|||
|
||||
Ok(OlmMachine {
|
||||
inner: block_on(InnerMachine::new_with_default_store(
|
||||
&user_id,
|
||||
device_id,
|
||||
path,
|
||||
Some("DEFAULT_PASSPHRASE"),
|
||||
&user_id, device_id, path, None,
|
||||
))?,
|
||||
runtime: Runtime::new().unwrap(),
|
||||
})
|
||||
|
|
|
@ -1,4 +1,10 @@
|
|||
namespace olm {};
|
||||
namespace olm {
|
||||
void set_logger(Logger logger);
|
||||
};
|
||||
|
||||
callback interface Logger {
|
||||
void log(string log_line);
|
||||
};
|
||||
|
||||
[Error]
|
||||
enum MachineCreationError {
|
||||
|
|
Loading…
Reference in a new issue