pub struct RiAuthConfig {
pub enabled: bool,
pub jwt_secret: String,
pub jwt_expiry_secs: u64,
pub session_timeout_secs: u64,
pub oauth_providers: Vec<String>,
pub enable_api_keys: bool,
pub enable_session_auth: bool,
pub oauth_cache_backend_type: RiCacheBackendType,
pub oauth_cache_redis_url: String,
}Expand description
Configuration for the authentication module.
This struct defines the configuration options for authentication behavior, including JWT settings, session settings, OAuth providers, and enabled authentication methods.
§Security
The JWT secret is loaded from the Ri_JWT_SECRET environment variable. If not set,
a cryptographically secure random secret is generated automatically.
Important: For production environments, always set the Ri_JWT_SECRET environment
variable to a strong, unique value. Do not rely on auto-generated secrets in production.
Fields§
§enabled: boolWhether authentication is enabled
jwt_secret: StringSecret key for JWT token generation and validation
jwt_expiry_secs: u64JWT token expiry time in seconds
session_timeout_secs: u64Session timeout in seconds
oauth_providers: Vec<String>List of OAuth providers to enable
enable_api_keys: boolWhether API key authentication is enabled
enable_session_auth: boolWhether session authentication is enabled
oauth_cache_backend_type: RiCacheBackendTypeOAuth token cache backend type (Memory or Redis)
oauth_cache_redis_url: StringRedis URL for OAuth token cache (used when backend is Redis)
Trait Implementations§
Source§impl Clone for RiAuthConfig
impl Clone for RiAuthConfig
Source§fn clone(&self) -> RiAuthConfig
fn clone(&self) -> RiAuthConfig
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for RiAuthConfig
impl Debug for RiAuthConfig
Source§impl Default for RiAuthConfig
impl Default for RiAuthConfig
Source§impl<'de> Deserialize<'de> for RiAuthConfig
impl<'de> Deserialize<'de> for RiAuthConfig
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl<'py> IntoPyObject<'py> for RiAuthConfig
impl<'py> IntoPyObject<'py> for RiAuthConfig
Source§type Target = RiAuthConfig
type Target = RiAuthConfig
Source§type Output = Bound<'py, <RiAuthConfig as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <RiAuthConfig 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 RiAuthConfig
impl PyClass for RiAuthConfig
Source§impl PyClassImpl for RiAuthConfig
impl PyClassImpl for RiAuthConfig
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"Configuration for the authentication module.\n\nThis struct defines the configuration options for authentication behavior, including\nJWT settings, session settings, OAuth providers, and enabled authentication methods.\n\n## Security\n\nThe JWT secret is loaded from the `Ri_JWT_SECRET` environment variable. If not set,\na cryptographically secure random secret is generated automatically.\n\n**Important**: For production environments, always set the `Ri_JWT_SECRET` environment\nvariable to a strong, unique value. Do not rely on auto-generated secrets in production.\x00"
const RAW_DOC: &'static CStr = c"Configuration for the authentication module.\n\nThis struct defines the configuration options for authentication behavior, including\nJWT settings, session settings, OAuth providers, and enabled authentication methods.\n\n## Security\n\nThe JWT secret is loaded from the `Ri_JWT_SECRET` environment variable. If not set,\na cryptographically secure random secret is generated automatically.\n\n**Important**: For production environments, always set the `Ri_JWT_SECRET` environment\nvariable to a strong, unique value. Do not rely on auto-generated secrets in production.\x00"
Source§const DOC: &'static CStr
const DOC: &'static CStr
text_signature if a constructor is defined. Read moreSource§type ThreadChecker = SendablePyClass<RiAuthConfig>
type ThreadChecker = SendablePyClass<RiAuthConfig>
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 RiAuthConfig
impl PyClassNewTextSignature for RiAuthConfig
const TEXT_SIGNATURE: &'static str = "(enabled=True, jwt_secret=\"\", jwt_expiry_secs=3600, session_timeout_secs=86400, oauth_providers=..., enable_api_keys=True, enable_session_auth=True, oauth_cache_backend_type=None, oauth_cache_redis_url=\"redis://127.0.0.1:6379\")"
Source§impl PyMethods<RiAuthConfig> for PyClassImplCollector<RiAuthConfig>
impl PyMethods<RiAuthConfig> for PyClassImplCollector<RiAuthConfig>
fn py_methods(self) -> &'static PyClassItems
Source§impl PyTypeInfo for RiAuthConfig
impl PyTypeInfo for RiAuthConfig
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 RiAuthConfig
impl ExtractPyClassWithClone for RiAuthConfig
Auto Trait Implementations§
impl Freeze for RiAuthConfig
impl RefUnwindSafe for RiAuthConfig
impl Send for RiAuthConfig
impl Sync for RiAuthConfig
impl Unpin for RiAuthConfig
impl UnsafeUnpin for RiAuthConfig
impl UnwindSafe for RiAuthConfig
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