shield_oidc/
storage.rs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
use async_trait::async_trait;

use shield::{Storage, StorageError, User};

use crate::{
    connection::{CreateOidcConnection, OidcConnection, UpdateOidcConnection},
    subprovider::OidcSubprovider,
};

#[async_trait]
pub trait OidcStorage<U: User>: Storage<U> + Sync {
    async fn oidc_subproviders(&self) -> Result<Vec<OidcSubprovider>, StorageError>;

    async fn oidc_subprovider_by_id(
        &self,
        subprovider_id: &str,
    ) -> Result<Option<OidcSubprovider>, StorageError>;

    async fn oidc_connection_by_id(
        &self,
        connection_id: &str,
    ) -> Result<Option<OidcConnection>, StorageError>;

    async fn oidc_connection_by_identifier(
        &self,
        subprovider_id: &str,
        identifier: &str,
    ) -> Result<Option<OidcConnection>, StorageError>;

    async fn create_oidc_connection(
        &self,
        connection: CreateOidcConnection,
    ) -> Result<OidcConnection, StorageError>;

    async fn update_oidc_connection(
        &self,
        connection: UpdateOidcConnection,
    ) -> Result<OidcConnection, StorageError>;

    async fn delete_oidc_connection(&self, connection_id: &str) -> Result<(), StorageError>;
}