Skip to content

Dead easy sanitizing for rust structs

License

Notifications You must be signed in to change notification settings

Expurple/sanitizer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

58 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

sanitizer

Inspired by the validator crate. The Sanitizer crate is a collection of methods and a macro to sanitize struct fields, leveraging the macros of rust, it follows the elegant approach by the validator crate.

Overview

[dependencies]
sanitizer = { version = "0.1", features = ["derive"] }

Then to use the crate

use sanitizer::prelude::*;

#[derive(Debug, Sanitize)]
struct SignupData {
    #[sanitize(trim, lower_case)]
    mail: String,
    #[sanitize(clamp(1, 60))]
    age: u8,
    #[sanitize]
    user: User,
}

#[derive(Debug, Sanitize)]
struct User {
    id: u64,
    #[sanitize(trim, clamp(50))]
    name: String,
}

fn main() {
    let instance = SignupData::new();
    instance.sanitize();
}

If you do not want to use the derive macro, then the sanitizer crate provides structures and methods for sanitizing ints

let int: u8 = 50;
let mut instance = IntSanitizer::from(int);
instance.clamp(99, 101);
assert_eq!(99, instance.get());

and strings

let mut sanitize = StringSanitizer::from("    some_string12 ");
sanitize.trim().numeric();
assert_eq!("12", sanitize.get());

Sanitizers

trim

Removes whitespace from ends.

numeric

Removes any character that is not a numeric.

alphanumeric

Removes any character that is not an alphanumeric.

lower_case

Converts string input to lowercase.

upper_case

Converts string input to UPPERCASE.

camel_case

Converts string input to camelCase.

snake_case

Converts string input to snake_case.

screaming_snake_case

Converts string input to SCREAMING_SNAKE_CASE using the Inflector crate.

e164

Converts string input to E164 International Phone Number format. This panics if the phone number is not a valid one.

clamp(min, max)

Limit an valid integer field with the given min and max.

clamp(max)

Limit a string input length to the following number

custom(function)

Use a custom function to sanitize a field differently. For example

#[derive(Sanitize)]
struct SanitizerTest {
    #[sanitize(custom(func_string))]
    field_string: String,
}

fn func_string(field: &str) -> String {
    let mut sanitizer = StringSanitizer::from(field);
    sanitizer.trim();
    sanitizer.get()
}

#[test]
fn sanitizer_check_custom_functions() {
    let mut instance = SanitizerTest {
        field_string: String::from("Hello    "),
    };
    instance.sanitize();
    assert_eq!(instance.field_string, String::from("Hello"));
}

nesting

#[derive(Sanitize)]
struct First {
    #[sanitize(trim)]
    name: String,
    #[sanitize]
    info: OtherInfo,
}

#[derive(Sanitize)]
struct OtherInfo {
    #[sanitize(numeric)]
    id: String,
    #[sanitize(lower_case, trim)]
    email: String,
}

The sanitize method of First will call the sanitizer method of OtherInfo automatically, if you would like to individually snaitize OtherInfo then you can just call snaitize on one of its instance.

LICENSE

dashxhq/sanitizer is licensed under the MIT License.

About

Dead easy sanitizing for rust structs

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Rust 100.0%