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
Move the SiteConfig to the data-model crate
This commit is contained in:
@@ -91,7 +91,7 @@ pub use self::{
|
||||
activity_tracker::{ActivityTracker, Bound as BoundActivityTracker},
|
||||
graphql::schema as graphql_schema,
|
||||
preferred_language::PreferredLanguage,
|
||||
site_config::SiteConfig,
|
||||
site_config::{SiteConfig, SiteConfigExt},
|
||||
upstream_oauth2::cache::MetadataCache,
|
||||
};
|
||||
|
||||
|
@@ -12,30 +12,17 @@
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
use chrono::Duration;
|
||||
pub use mas_data_model::SiteConfig;
|
||||
use mas_templates::{SiteBranding, SiteFeatures};
|
||||
use url::Url;
|
||||
|
||||
/// Random site configuration we don't now where to put yet.
|
||||
#[allow(clippy::struct_excessive_bools)]
|
||||
#[derive(Debug, Clone)]
|
||||
pub struct SiteConfig {
|
||||
pub access_token_ttl: Duration,
|
||||
pub compat_token_ttl: Duration,
|
||||
pub server_name: String,
|
||||
pub policy_uri: Option<Url>,
|
||||
pub tos_uri: Option<Url>,
|
||||
pub imprint: Option<String>,
|
||||
pub password_login_enabled: bool,
|
||||
pub password_registration_enabled: bool,
|
||||
pub email_change_allowed: bool,
|
||||
pub displayname_change_allowed: bool,
|
||||
pub password_change_allowed: bool,
|
||||
#[allow(clippy::module_name_repetitions)]
|
||||
pub trait SiteConfigExt {
|
||||
fn templates_branding(&self) -> SiteBranding;
|
||||
fn templates_features(&self) -> SiteFeatures;
|
||||
}
|
||||
|
||||
impl SiteConfig {
|
||||
#[must_use]
|
||||
pub fn templates_branding(&self) -> SiteBranding {
|
||||
impl SiteConfigExt for SiteConfig {
|
||||
fn templates_branding(&self) -> SiteBranding {
|
||||
let mut branding = SiteBranding::new(self.server_name.clone());
|
||||
|
||||
if let Some(policy_uri) = &self.policy_uri {
|
||||
@@ -53,8 +40,7 @@ impl SiteConfig {
|
||||
branding
|
||||
}
|
||||
|
||||
#[must_use]
|
||||
pub fn templates_features(&self) -> SiteFeatures {
|
||||
fn templates_features(&self) -> SiteFeatures {
|
||||
SiteFeatures {
|
||||
password_registration: self.password_registration_enabled,
|
||||
password_login: self.password_login_enabled,
|
||||
|
@@ -56,7 +56,7 @@ use crate::{
|
||||
passwords::{Hasher, PasswordManager},
|
||||
site_config::SiteConfig,
|
||||
upstream_oauth2::cache::MetadataCache,
|
||||
ActivityTracker, BoundActivityTracker,
|
||||
ActivityTracker, BoundActivityTracker, SiteConfigExt,
|
||||
};
|
||||
|
||||
// This might fail if it's not the first time it's being called, which is fine,
|
||||
|
Reference in New Issue
Block a user