tower_oauth2_resource_server/
validation.rs

1use std::fmt::Display;
2
3#[derive(Clone, Debug, Default, Eq, PartialEq)]
4pub struct ClaimsValidationSpec {
5    pub iss: Option<String>,
6    pub exp: bool,
7    pub nbf: bool,
8    pub aud: Vec<String>,
9}
10
11impl ClaimsValidationSpec {
12    pub fn new() -> Self {
13        Self {
14            ..Default::default()
15        }
16    }
17
18    pub fn recommended(issuer: &str, audiences: &Vec<String>) -> Self {
19        Self::new().exp(true).nbf(true).iss(issuer).aud(audiences)
20    }
21
22    pub fn iss(mut self, issuer: &str) -> Self {
23        self.iss = Some(issuer.to_owned());
24        self
25    }
26
27    pub fn exp(mut self, validate: bool) -> Self {
28        self.exp = validate;
29        self
30    }
31
32    pub fn nbf(mut self, validate: bool) -> Self {
33        self.nbf = validate;
34        self
35    }
36
37    pub fn aud(mut self, audiences: &Vec<String>) -> Self {
38        self.aud = audiences.to_owned();
39        self
40    }
41}
42
43impl Display for ClaimsValidationSpec {
44    fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
45        write!(f, "{:?}", self)
46    }
47}