// Copyright 2021, 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 mas_data_model::Session; use sqlx::PgExecutor; use uuid::Uuid; use crate::{Clock, PostgresqlBackend}; pub mod access_token; pub mod authorization_grant; pub mod client; pub mod consent; pub mod refresh_token; #[tracing::instrument( skip_all, fields( session.id = %session.data, user.id = %session.browser_session.user.data, user_session.id = %session.browser_session.data, client.id = %session.client.data, ), err(Debug), )] pub async fn end_oauth_session( executor: impl PgExecutor<'_>, clock: &Clock, session: Session, ) -> Result<(), anyhow::Error> { let finished_at = clock.now(); let res = sqlx::query!( r#" UPDATE oauth2_sessions SET finished_at = $2 WHERE oauth2_session_id = $1 "#, Uuid::from(session.data), finished_at, ) .execute(executor) .await?; anyhow::ensure!(res.rows_affected() == 1); Ok(()) }