You've already forked authentication-service
mirror of
https://github.com/matrix-org/matrix-authentication-service.git
synced 2025-11-23 11:02:35 +03:00
71 lines
2.1 KiB
Rust
71 lines
2.1 KiB
Rust
// Copyright 2022 The Matrix.org Foundation C.I.C.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
use http::header::HeaderName;
|
|
use once_cell::sync::OnceCell;
|
|
use tower_http::cors::CorsLayer;
|
|
|
|
use crate::layers::json::Json;
|
|
|
|
static PROPAGATOR_HEADERS: OnceCell<Vec<HeaderName>> = OnceCell::new();
|
|
|
|
/// Notify the CORS layer what opentelemetry propagators are being used. This
|
|
/// helps whitelisting headers in CORS requests.
|
|
///
|
|
/// # Panics
|
|
///
|
|
/// When called twice
|
|
pub fn set_propagator(propagator: &dyn opentelemetry::propagation::TextMapPropagator) {
|
|
let headers = propagator
|
|
.fields()
|
|
.map(|h| HeaderName::try_from(h).unwrap())
|
|
.collect();
|
|
|
|
tracing::debug!(
|
|
?headers,
|
|
"Headers allowed in CORS requests for trace propagators set"
|
|
);
|
|
PROPAGATOR_HEADERS
|
|
.set(headers)
|
|
.expect(concat!(module_path!(), "::set_propagator was called twice"));
|
|
}
|
|
|
|
pub trait CorsLayerExt {
|
|
#[must_use]
|
|
fn allow_otel_headers<H>(self, headers: H) -> Self
|
|
where
|
|
H: IntoIterator<Item = HeaderName>;
|
|
}
|
|
|
|
impl CorsLayerExt for CorsLayer {
|
|
fn allow_otel_headers<H>(self, headers: H) -> Self
|
|
where
|
|
H: IntoIterator<Item = HeaderName>,
|
|
{
|
|
let base = PROPAGATOR_HEADERS.get().cloned().unwrap_or_default();
|
|
let headers: Vec<_> = headers.into_iter().chain(base.into_iter()).collect();
|
|
self.allow_headers(headers)
|
|
}
|
|
}
|
|
|
|
pub trait ServiceExt: Sized {
|
|
fn json<T>(self) -> Json<Self, T>;
|
|
}
|
|
|
|
impl<S> ServiceExt for S {
|
|
fn json<T>(self) -> Json<Self, T> {
|
|
Json::new(self)
|
|
}
|
|
}
|