2019-10-21 07:18:51 +00:00
|
|
|
use std::io::Cursor;
|
2018-04-12 04:14:16 +00:00
|
|
|
|
2019-10-21 07:18:51 +00:00
|
|
|
use bytes::Bytes;
|
2020-05-08 03:14:43 +00:00
|
|
|
use futures::{TryStream, TryStreamExt};
|
|
|
|
use tokio_util::codec::{BytesCodec, FramedRead};
|
2018-10-21 06:25:24 +00:00
|
|
|
use webmetro::error::WebmetroError;
|
2018-04-12 04:14:16 +00:00
|
|
|
|
2018-04-12 01:54:02 +00:00
|
|
|
pub mod dump;
|
2018-04-12 06:03:46 +00:00
|
|
|
pub mod filter;
|
2018-04-11 05:39:28 +00:00
|
|
|
pub mod relay;
|
2018-04-15 05:43:23 +00:00
|
|
|
pub mod send;
|
2018-04-12 04:14:16 +00:00
|
|
|
|
2018-04-14 22:18:50 +00:00
|
|
|
/// An adapter that makes chunks of bytes from stdin available as a Stream;
|
|
|
|
/// is NOT actually async, and just uses blocking read. Don't use more than
|
|
|
|
/// one at once, who knows who gets which bytes.
|
2020-05-08 03:14:43 +00:00
|
|
|
pub fn stdin_stream() -> impl TryStream<
|
2019-10-21 07:18:51 +00:00
|
|
|
Item = Result<Cursor<Bytes>, WebmetroError>,
|
|
|
|
Ok = Cursor<Bytes>,
|
|
|
|
Error = WebmetroError,
|
|
|
|
> + Sized
|
|
|
|
+ Unpin {
|
2020-05-08 03:14:43 +00:00
|
|
|
FramedRead::new(tokio::io::stdin(), BytesCodec::new())
|
2019-10-21 07:18:51 +00:00
|
|
|
.map_ok(|bytes| Cursor::new(bytes.freeze()))
|
|
|
|
.map_err(WebmetroError::from)
|
2018-04-12 04:14:16 +00:00
|
|
|
}
|