1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
use {
anyhow::{format_err, Error},
diagnostics_log_encoding::encode::{Encoder, EncodingError},
fidl_fuchsia_mem::Buffer,
fidl_fuchsia_validate_logs::{EncodingPuppetRequest, EncodingPuppetRequestStream, PuppetError},
fuchsia_component::server::ServiceFs,
fuchsia_zircon::Vmo,
futures::prelude::*,
std::io::Cursor,
tracing::*,
};
const BUFFER_SIZE: usize = 1024;
async fn run_encoding_service(mut stream: EncodingPuppetRequestStream) -> Result<(), Error> {
while let Some(request) = stream.try_next().await? {
let EncodingPuppetRequest::Encode { record, responder } = request;
let mut buffer = Cursor::new(vec![0u8; BUFFER_SIZE]);
let mut encoder = Encoder::new(&mut buffer);
match encoder.write_record(&record) {
Ok(()) => {
let encoded = &buffer.get_ref().as_slice()[..buffer.position() as usize];
let vmo = Vmo::create(BUFFER_SIZE as u64)?;
vmo.write(&encoded, 0)?;
responder.send(&mut Ok(Buffer { vmo, size: encoded.len() as u64 }))?;
}
Err(EncodingError::Unsupported) => {
responder.send(&mut Err(PuppetError::UnsupportedRecord))?
}
Err(e) => {
return Err(format_err!("Error parsing record: {:?}", e));
}
}
}
Ok(())
}
enum IncomingService {
Encoding(EncodingPuppetRequestStream),
}
#[fuchsia::main]
async fn main() -> Result<(), Error> {
let mut fs = ServiceFs::new_local();
fs.dir("svc").add_fidl_service(IncomingService::Encoding);
fs.take_and_serve_directory_handle()?;
const MAX_CONCURRENT: usize = 4;
fs.for_each_concurrent(MAX_CONCURRENT, |IncomingService::Encoding(stream)| {
run_encoding_service(stream).unwrap_or_else(|e| error!("ERROR in puppet's main: {:?}", e))
})
.await;
Ok(())
}