pub struct RiLogConfig {
pub level: RiLogLevel,
pub console_enabled: bool,
pub file_enabled: bool,
pub sampling_default: f32,
pub file_name: String,
pub json_format: bool,
pub rotate_when: String,
pub max_bytes: u64,
pub color_blocks: bool,
}Expand description
Public logging configuration class.
This struct defines the configuration options for the Ri logging system, including log level, output formats, sampling, and log rotation settings.
Fields§
§level: RiLogLevelMinimum log level to be logged
console_enabled: boolWhether console logging is enabled
file_enabled: boolWhether file logging is enabled
sampling_default: f32Default sampling rate (0.0 to 1.0, where 1.0 means all logs are sampled)
file_name: StringName of the log file
json_format: boolWhether to use JSON format for logs
rotate_when: StringWhen to rotate logs (currently only “size” or “none” are supported)
max_bytes: u64Maximum file size in bytes before rotation (used when rotate_when == “size”)
color_blocks: boolWhether to use color blocks in log output
Implementations§
Source§impl RiLogConfig
impl RiLogConfig
Sourcepub fn from_config(config: &RiConfig) -> Self
pub fn from_config(config: &RiConfig) -> Self
Creates a log configuration from a RiConfig instance.
This method reads logging configuration from a RiConfig instance, using the following keys:
- log.level: Log level (DEBUG, INFO, WARN, ERROR)
- log.console_enabled: Whether console logging is enabled
- log.file_enabled: Whether file logging is enabled
- log.sampling_default: Default sampling rate
- log.file_name: Name of the log file
- log.file_format: Log format (“json” for JSON format, anything else for text)
- log.rotate_when: When to rotate logs
- log.max_bytes: Maximum file size before rotation
§Parameters
config: TheRiConfiginstance to read from
§Returns
A RiLogConfig instance with configuration from the given RiConfig
Sourcepub fn from_env() -> Self
pub fn from_env() -> Self
Creates a log configuration from environment variables.
This method reads logging configuration from environment variables:
- Ri_LOG_LEVEL: Log level (DEBUG, INFO, WARN, ERROR)
- Ri_LOG_CONSOLE_ENABLED: Whether console logging is enabled (true/false)
- Ri_LOG_FILE_ENABLED: Whether file logging is enabled (true/false)
- Ri_LOG_SAMPLING_DEFAULT: Default sampling rate (0.0-1.0)
- Ri_LOG_FILE_NAME: Name of the log file
- Ri_LOG_FILE_FORMAT: Log format (“json” for JSON format)
- Ri_LOG_ROTATE_WHEN: When to rotate logs
- Ri_LOG_MAX_BYTES: Maximum file size before rotation
§Returns
A RiLogConfig instance with configuration from environment variables
Trait Implementations§
Source§impl Clone for RiLogConfig
impl Clone for RiLogConfig
Source§fn clone(&self) -> RiLogConfig
fn clone(&self) -> RiLogConfig
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Default for RiLogConfig
Default implementation for RiLogConfig
impl Default for RiLogConfig
Default implementation for RiLogConfig
Source§impl<'py> IntoPyObject<'py> for RiLogConfig
impl<'py> IntoPyObject<'py> for RiLogConfig
Source§type Target = RiLogConfig
type Target = RiLogConfig
Source§type Output = Bound<'py, <RiLogConfig as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <RiLogConfig as IntoPyObject<'py>>::Target>
Source§fn into_pyobject(
self,
py: Python<'py>,
) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
fn into_pyobject( self, py: Python<'py>, ) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
Source§impl PyClass for RiLogConfig
impl PyClass for RiLogConfig
Source§impl PyClassImpl for RiLogConfig
impl PyClassImpl for RiLogConfig
Source§const IS_BASETYPE: bool = false
const IS_BASETYPE: bool = false
Source§const IS_SUBCLASS: bool = false
const IS_SUBCLASS: bool = false
Source§const IS_MAPPING: bool = false
const IS_MAPPING: bool = false
Source§const IS_SEQUENCE: bool = false
const IS_SEQUENCE: bool = false
Source§const IS_IMMUTABLE_TYPE: bool = false
const IS_IMMUTABLE_TYPE: bool = false
Source§const RAW_DOC: &'static CStr = c"Public logging configuration class.\n\nThis struct defines the configuration options for the Ri logging system, including\nlog level, output formats, sampling, and log rotation settings.\x00"
const RAW_DOC: &'static CStr = c"Public logging configuration class.\n\nThis struct defines the configuration options for the Ri logging system, including\nlog level, output formats, sampling, and log rotation settings.\x00"
Source§const DOC: &'static CStr
const DOC: &'static CStr
text_signature if a constructor is defined. Read moreSource§type ThreadChecker = SendablePyClass<RiLogConfig>
type ThreadChecker = SendablePyClass<RiLogConfig>
Source§type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
Source§type BaseNativeType = PyAny
type BaseNativeType = PyAny
PyAny by default, and when you declare
#[pyclass(extends=PyDict)], it’s PyDict.fn items_iter() -> PyClassItemsIter
fn lazy_type_object() -> &'static LazyTypeObject<Self>
fn dict_offset() -> Option<isize>
fn weaklist_offset() -> Option<isize>
Source§impl PyClassNewTextSignature for RiLogConfig
impl PyClassNewTextSignature for RiLogConfig
const TEXT_SIGNATURE: &'static str = "()"
Source§impl PyMethods<RiLogConfig> for PyClassImplCollector<RiLogConfig>
impl PyMethods<RiLogConfig> for PyClassImplCollector<RiLogConfig>
fn py_methods(self) -> &'static PyClassItems
Source§impl PyTypeInfo for RiLogConfig
impl PyTypeInfo for RiLogConfig
Source§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
§fn type_object(py: Python<'_>) -> Bound<'_, PyType>
fn type_object(py: Python<'_>) -> Bound<'_, PyType>
§fn is_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_type_of(object: &Bound<'_, PyAny>) -> bool
object is an instance of this type or a subclass of this type.§fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
object is an instance of this type.impl DerefToPyAny for RiLogConfig
impl ExtractPyClassWithClone for RiLogConfig
Auto Trait Implementations§
impl Freeze for RiLogConfig
impl RefUnwindSafe for RiLogConfig
impl Send for RiLogConfig
impl Sync for RiLogConfig
impl Unpin for RiLogConfig
impl UnsafeUnpin for RiLogConfig
impl UnwindSafe for RiLogConfig
Blanket Implementations§
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
§fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
self into an owned Python object, dropping type information.§fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
self into an owned Python object, dropping type information and unbinding it
from the 'py lifetime.§fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
self into a Python object. Read moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T in a tonic::RequestSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T in a tonic::Request§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> PyErrArguments for T
impl<T> PyErrArguments for T
§impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
§const NAME: &'static str = T::NAME
const NAME: &'static str = T::NAME
§fn type_check(object: &Bound<'_, PyAny>) -> bool
fn type_check(object: &Bound<'_, PyAny>) -> bool
§fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
isinstance and issubclass function. Read more