8 releases
new 0.2.0 | Oct 30, 2024 |
---|---|
0.1.7 | Nov 20, 2023 |
0.1.6 | May 4, 2023 |
0.1.5 | Dec 22, 2022 |
0.1.0 |
|
#1751 in Procedural macros
22,926 downloads per month
Used in 2 crates
(via veil)
40KB
773 lines
A derive macro that implements std::fmt::Debug
for a struct or enum variant, with certain fields redacted.
The purpose of this macro is to allow for easy, configurable and efficient redaction of sensitive data in structs and enum variants. This can be used to hide sensitive data in logs or anywhere where personal data should not be exposed or stored.
Usage
Add to your Cargo.toml:
[dependencies]
veil = "0.2.0"
Usage documentation can be found here.
Example
The example is explained in detail here.
#[derive(Redact)]
struct CreditCard {
#[redact(partial)]
number: String,
#[redact]
expiry: String,
#[redact(fixed = 3)]
cvv: String,
#[redact(partial)]
cardholder_name: String,
}
#[derive(Redact)]
#[redact(all, variant)]
enum CreditCardIssuer {
MasterCard,
Visa,
AmericanExpress,
}
#[derive(Redact)]
#[redact(all, partial)]
struct Vehicle {
license_plate: String,
make: String,
model: String,
color: String,
}
#[derive(Debug)]
struct Policy {
id: Uuid,
name: String,
description: String,
}
#[derive(Redact)]
enum InsuranceStatus {
#[redact(all, partial)]
Insured {
#[redact(fixed = 12)]
policy: Policy,
policy_started: String,
policy_expires: String,
#[redact(skip)]
payment_card: CreditCard,
#[redact(skip)]
vehicles: Vec<Vehicle>,
},
Uninsured {
policies_available: Vec<Policy>,
},
}
Environmental Awareness
In testing environments it may be useful to disable redaction entirely. You can globally disable Veil's redaction behavior at runtime by enabling the non-default feature flag toggle
and:
- Setting the
VEIL_DISABLE_REDACTION
environment variable to "1", "true" or "on" (case insensitive).
OR
- Calling the
veil::disable
function. See this example.
These are only checked ONCE for security purposes.
Dependencies
~255–710KB
~17K SLoC