mirror of
https://github.com/meilisearch/MeiliSearch
synced 2024-11-26 23:04:26 +01:00
policies macros
This commit is contained in:
parent
12f6709e1c
commit
5b71751391
@ -1,4 +1,4 @@
|
|||||||
use std::collections::HashMap;
|
use std::collections::{HashMap, HashSet};
|
||||||
use std::marker::PhantomData;
|
use std::marker::PhantomData;
|
||||||
use std::ops::Deref;
|
use std::ops::Deref;
|
||||||
use std::any::{Any, TypeId};
|
use std::any::{Any, TypeId};
|
||||||
@ -9,12 +9,59 @@ use futures::future::{Ready, ok};
|
|||||||
|
|
||||||
use crate::error::{AuthenticationError, ResponseError};
|
use crate::error::{AuthenticationError, ResponseError};
|
||||||
|
|
||||||
pub struct Public;
|
macro_rules! create_policies {
|
||||||
|
($($name:ident), *) => {
|
||||||
impl Policy for Public {
|
$(
|
||||||
fn authenticate(&self, _token: &[u8]) -> bool {
|
pub struct $name {
|
||||||
true
|
inner: HashSet<Vec<u8>>
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl $name {
|
||||||
|
pub fn new() -> Self {
|
||||||
|
Self { inner: HashSet::new() }
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn add(&mut self, token: Vec<u8>) {
|
||||||
|
self.inner.insert(token);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Policy for $name {
|
||||||
|
fn authenticate(&self, token: &[u8]) -> bool {
|
||||||
|
self.inner.contains(token)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)*
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
create_policies!(Public, Private, Admin);
|
||||||
|
|
||||||
|
/// Instanciate a `Policies`, filled with the given policies.
|
||||||
|
macro_rules! init_policies {
|
||||||
|
($($name:ident), *) => {
|
||||||
|
{
|
||||||
|
let mut policies = Policies::new();
|
||||||
|
$(
|
||||||
|
let policy = $name::new();
|
||||||
|
policies.insert(policy);
|
||||||
|
)*
|
||||||
|
policies
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Adds user to all specified policies.
|
||||||
|
macro_rules! create_users {
|
||||||
|
($policies:ident, $($user:literal => { $($policy:ty), * }), *) => {
|
||||||
|
{
|
||||||
|
$(
|
||||||
|
$(
|
||||||
|
$policies.get_mut::<$policy>().map(|p| p.add($user.to_owned()))
|
||||||
|
)*
|
||||||
|
)*
|
||||||
|
}
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct GuardedData<T, D> {
|
pub struct GuardedData<T, D> {
|
||||||
@ -52,6 +99,11 @@ impl Policies {
|
|||||||
.get(&TypeId::of::<S>())
|
.get(&TypeId::of::<S>())
|
||||||
.and_then(|p| p.downcast_ref::<S>())
|
.and_then(|p| p.downcast_ref::<S>())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn get_mut<S: Policy + 'static>(&mut self) -> Option<&mut S> {
|
||||||
|
self.inner.get_mut(&TypeId::of::<S>())
|
||||||
|
.and_then(|p| p.downcast_mut::<S>())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Default for Policies {
|
impl Default for Policies {
|
||||||
|
@ -1,2 +1,3 @@
|
|||||||
pub mod payload;
|
pub mod payload;
|
||||||
|
#[macro_use]
|
||||||
pub mod authentication;
|
pub mod authentication;
|
||||||
|
@ -35,6 +35,10 @@ pub fn configure_data(config: &mut web::ServiceConfig, data: Data) {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn configure_auth(config: &mut web::ServiceConfig, opt: &Options) {
|
||||||
|
todo!()
|
||||||
|
}
|
||||||
|
|
||||||
#[cfg(feature = "mini-dashboard")]
|
#[cfg(feature = "mini-dashboard")]
|
||||||
pub fn dashboard(config: &mut web::ServiceConfig, enable_frontend: bool) {
|
pub fn dashboard(config: &mut web::ServiceConfig, enable_frontend: bool) {
|
||||||
use actix_web_static_files::Resource;
|
use actix_web_static_files::Resource;
|
||||||
|
@ -13,7 +13,7 @@ use crate::extractors::authentication::{Policies, AuthConfig, Public, GuardedDat
|
|||||||
|
|
||||||
pub fn services(cfg: &mut web::ServiceConfig) {
|
pub fn services(cfg: &mut web::ServiceConfig) {
|
||||||
let mut policies = Policies::new();
|
let mut policies = Policies::new();
|
||||||
policies.insert(Public);
|
policies.insert(Public::new());
|
||||||
cfg.service(
|
cfg.service(
|
||||||
web::resource("/indexes/{index_uid}/search")
|
web::resource("/indexes/{index_uid}/search")
|
||||||
.app_data(AuthConfig::Auth(policies))
|
.app_data(AuthConfig::Auth(policies))
|
||||||
|
Loading…
Reference in New Issue
Block a user