summaryrefslogtreecommitdiff
path: root/src/lib.rs
blob: a82c2aced8e0698bb3528c245b73088f1d474b03 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
pub mod authorization;
pub use authorization::{Authorizer, CedarAuthorizer, CheckService};

use envoy_types::ext_authz::v3::pb::AuthorizationServer;
use std::sync::Arc;
use tonic::transport::Server;

pub fn create_server() -> Result<tonic::transport::server::Router, Box<dyn std::error::Error>> {
    let (_health_reporter, health_service) = tonic_health::server::health_reporter();
    let authorizer = Arc::new(authorization::CedarAuthorizer::default());
    let check_service = authorization::CheckService::new(authorizer);
    let server = Server::builder()
        .add_service(AuthorizationServer::new(check_service))
        .add_service(health_service)
        .add_service(
            tonic_reflection::server::Builder::configure()
                .register_encoded_file_descriptor_set(tonic_health::pb::FILE_DESCRIPTOR_SET)
                .build_v1()
                .unwrap(),
        );
    Ok(server)
}