You've already forked authentication-service
mirror of
https://github.com/matrix-org/matrix-authentication-service.git
synced 2025-08-09 04:22:45 +03:00
Add the Sentry event ID in error response headers
This commit is contained in:
@@ -19,6 +19,8 @@ use axum::{
|
||||
};
|
||||
use mas_templates::ErrorContext;
|
||||
|
||||
use crate::sentry::SentryEventID;
|
||||
|
||||
pub struct FancyError {
|
||||
context: ErrorContext,
|
||||
}
|
||||
@@ -59,9 +61,10 @@ impl<E: std::fmt::Debug + std::fmt::Display> From<E> for FancyError {
|
||||
impl IntoResponse for FancyError {
|
||||
fn into_response(self) -> Response {
|
||||
let error = format!("{:?}", self.context);
|
||||
sentry::capture_message(&error, sentry::Level::Error);
|
||||
let event_id = sentry::capture_message(&error, sentry::Level::Error);
|
||||
(
|
||||
StatusCode::INTERNAL_SERVER_ERROR,
|
||||
SentryEventID::from(event_id),
|
||||
Extension(self.context),
|
||||
error,
|
||||
)
|
||||
|
@@ -28,6 +28,7 @@ pub mod csrf;
|
||||
pub mod fancy_error;
|
||||
pub mod http_client_factory;
|
||||
pub mod jwt;
|
||||
pub mod sentry;
|
||||
pub mod session;
|
||||
pub mod user_authorization;
|
||||
|
||||
|
38
crates/axum-utils/src/sentry.rs
Normal file
38
crates/axum-utils/src/sentry.rs
Normal file
@@ -0,0 +1,38 @@
|
||||
// Copyright 2023 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 std::convert::Infallible;
|
||||
|
||||
use axum::response::{IntoResponseParts, ResponseParts};
|
||||
use sentry::types::Uuid;
|
||||
|
||||
/// A wrapper to include a Sentry event ID in the response headers.
|
||||
#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)]
|
||||
pub struct SentryEventID(Uuid);
|
||||
|
||||
impl From<Uuid> for SentryEventID {
|
||||
fn from(uuid: Uuid) -> Self {
|
||||
Self(uuid)
|
||||
}
|
||||
}
|
||||
|
||||
impl IntoResponseParts for SentryEventID {
|
||||
type Error = Infallible;
|
||||
fn into_response_parts(self, mut res: ResponseParts) -> Result<ResponseParts, Self::Error> {
|
||||
res.headers_mut()
|
||||
.insert("X-Sentry-Event-ID", self.0.to_string().parse().unwrap());
|
||||
|
||||
Ok(res)
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user