#casbin #rocket #middleware #authorization

nightly rocket_casbin_auth

Casbin Rocket访问控制中间件

1个不稳定版本

0.1.1 2020年8月27日
0.1.0 2020年8月26日

#1046 in 认证

Apache-2.0

8KB

Rocket Casbin中间件

Docs

用法

rocket_casbin_auth = "0.1.1"

指南

根据Rocket 公平处理指南,我们需要使用公平处理特质进行casbin认证或授权。

因此,您需要首先实现CasbinMiddlewareFairing

pub struct CasbinFairing {
    enforcer: Arc<RwLock<CachedEnforcer>>,
}

impl CasbinFairing {
    pub fn new<M: TryIntoModel, A: TryIntoAdapter>(m: M, a: A) -> CasbinFairing {
        let mut rt = tokio::runtime::Runtime::new().unwrap();
        match rt.block_on(casbin::CachedEnforcer::new(m, a)) {
            Ok(e) => CasbinFairing {
                enforcer: Arc::new(RwLock::new(e)),
            },
            Err(_) => panic!("CasbinFairing build failed"),
        }
    }
}

impl CasbinMiddleware for CasbinFairing {
    fn get_casbin_vals<'a>(&self, req: &Request<'_>) -> Vec<String> {
        let path = req.uri().path().to_owned();
        let sub = match req.cookies().get("name") {
            Some(cookie) => cookie.value().to_owned(),
            _ => "".to_owned(),
        };
        let method = req.method().as_str().to_owned();
        vec![sub, path, method]
    }

    fn get_cached_enforcer(&self) -> Arc<RwLock<CachedEnforcer>> {
        self.enforcer.clone()
    }
}

impl Fairing for CasbinFairing {
    fn info(&self) -> Info {
        Info {
            name: "Casbin Fairing",
            kind: Kind::Request,
        }
    }

    fn on_request(&self, req: &mut Request<'r>, _: &Data) {
        self.enforce(req);
    }
}

然后,将公平处理附加到Rocket。

rocket::ignite()
    .attach(CasbinFairing::new("examples/model.conf", "examples/role_policy.csv"))

完成,向您的路由添加保护器

#[get("/book/1")]
pub fn book(_g: CasbinGuard) -> &'static str {
    "book"
}

依赖项

~19MB
~358K SLoC