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
//! This library provides a [`LoggedStream`] structure which can be used as a wrapper for
//! underlying IO object which implements [`Write`] and [`Read`] traits or their
//! asynchronous analogues from [`tokio`] library to enable logging of all read and write
//! operations, errors and drop.
//!
//! [`LoggedStream`] structure constructs from four parts:
//!
//! - Underlying IO object, which must implement [`Write`] and [`Read`] traits or their
//! asynchronous analogues from [`tokio`] library: [`AsyncRead`] and [`AsyncWrite`].
//! - Buffer formatting part, which must implement [`BufferFormatter`] trait provided by
//! this library. This part of [`LoggedStream`] is responsible for the form you will see the
//! input and output bytes. Currently this library provides the following implementations of
//! [`BufferFormatter`] trait: [`UppercaseHexadecimalFormatter`], [`LowercaseHexadecimalFormatter`],
//! [`DecimalFormatter`], [`BinaryFormatter`] and [`OctalFormatter`]. Also [`BufferFormatter`] is
//! public trait so you are free to construct your own implementation.
//! - Filtering part, which must implement [`RecordFilter`] trait provided by this library.
//! This part of [`LoggedStream`] is responsible for log records filtering. Currently this
//! library provides the following implementations of [`RecordFilter`] trait: [`DefaultFilter`] which
//! accepts all log records, [`RecordKindFilter`] which accepts logs with kinds specified during
//! construct, [`AllFilter`] which combines multiple filters with AND logic (accepts record only if
//! all underlying filters accept it), and [`AnyFilter`] which combines multiple filters with OR logic
//! (accepts record if any underlying filter accepts it). Also [`RecordFilter`] is public trait and
//! you are free to construct your own implementation.
//! - Logging part, which must implement [`Logger`] trait provided by this library. This part
//! of [`LoggedStream`] is responsible for further work with constructed, formatter and filtered
//! log record. For example, it can be outputted to console, written to the file, written to database,
//! written to the memory for further use or sended by the channel. Currently this library provides
//! the following implementations of [`Logger`] trait: [`ConsoleLogger`], [`MemoryStorageLogger`],
//! [`ChannelLogger`] and [`FileLogger`]. Also [`Logger`] is public trait and you are free to construct
//! your own implementation.
//!
//! [`Write`]: std::io::Write
//! [`Read`]: std::io::Read
//! [`AsyncRead`]: tokio::io::AsyncRead
//! [`AsyncWrite`]: tokio::io::AsyncWrite
pub use BinaryFormatter;
pub use BufferFormatter;
pub use DecimalFormatter;
pub use LowercaseHexadecimalFormatter;
pub use OctalFormatter;
pub use UppercaseHexadecimalFormatter;
pub use AllFilter;
pub use AnyFilter;
pub use DefaultFilter;
pub use RecordFilter;
pub use RecordKindFilter;
pub use ChannelLogger;
pub use ConsoleLogger;
pub use FileLogger;
pub use Logger;
pub use MemoryStorageLogger;
pub use Record;
pub use RecordKind;
pub use LoggedStream;