ModSecurity

Struct ModSecurity 

Source
pub struct ModSecurity { /* private fields */ }
Expand description

Actix-Web compatible wrapper on ModSecurity

Implementations§

Source§

impl ModSecurity

Source

pub fn new() -> Self

Creates a new ModSecurity instance.

Because of implementation specifics of LibModSecurity, it is recommended only once instance exist within the program.

See modsecurity::msc::ModSecurity for more details.

Source

pub fn add_rules(&mut self, rules: &str) -> Result<&mut Self, Error>

Adds plain rules from string into the set.

§Examples
use actix_modsecurity::ModSecurity;

let mut security = ModSecurity::new();
security.add_rules("SecRuleEngine On\n").expect("Failed to add rules");
Source

pub fn add_rules_file<P: AsRef<Path>>( &mut self, file: P, ) -> Result<&mut Self, Error>

Adds rules from a file into the set.

§Examples
use actix_modsecurity::ModSecurity;

let mut security = ModSecurity::new();
security.add_rules_file("/path/to/rules.conf").expect("Failed to add rules from file");
Source

pub fn set_max_request_size( &mut self, max_request_body: Option<usize>, ) -> &mut Self

Configure Max request body size allowed to be loaded into memory for processing.

This avoids out-of-memory errors and potential security-risks from attackers overloading your web-service.

Source

pub fn set_max_response_size( &mut self, max_response_body: Option<usize>, ) -> &mut Self

Configure Max response body size allowed to be loaded into memory for processing.

This avoids out-of-memory errors and potential security-risks from attackers overloading your web-service.

Source

pub fn set_server_address( &mut self, server_address: Option<(String, u16)>, ) -> &mut Self

Include server bindings information to include in transaction processing.

Allows Transaction::process_connection to work as intended rather than skip over connection information.

Source

pub fn transaction(&self) -> Result<Transaction<'_>, Error>

Creates a configured LibModSecurity Transaction with the configured rules.

Source

pub fn middleware(self) -> Middleware

Converts ModSecurity Instance into Actix-Web Middleware

§Examples
use actix_web::App;
use actix_modsecurity::ModSecurity;

let mut security = ModSecurity::new();
security.add_rules("SecRuleEngine On\n").expect("Failed to add rules");

let app = App::new()
    .wrap(security.middleware());

Trait Implementations§

Source§

impl Into<Middleware> for ModSecurity

Source§

fn into(self) -> Middleware

Converts this type into the (usually inferred) input type.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> ErasedDestructor for T
where T: 'static,