mirror of
https://git.joinplu.me/Plume/Plume.git
synced 2025-01-25 20:28:07 +00:00
Extract Instance::create_local_instance_user() from get_local_instance_user_uncached()
This commit is contained in:
parent
2f7a5cbf56
commit
af5b0b961b
1 changed files with 15 additions and 13 deletions
|
@ -80,16 +80,7 @@ impl Instance {
|
||||||
.map_err(Error::from)
|
.map_err(Error::from)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_local_instance_user() -> Option<&'static User> {
|
pub fn create_local_instance_user(conn: &Connection) -> Result<User> {
|
||||||
LOCAL_INSTANCE_USER.get()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_local_instance_user_uncached(conn: &Connection) -> Result<User> {
|
|
||||||
users::table
|
|
||||||
.filter(users::role.eq(3))
|
|
||||||
.first(conn)
|
|
||||||
.or_else(|err| match err {
|
|
||||||
NotFound => {
|
|
||||||
let instance = Instance::get_local().expect("Failed to get local instance");
|
let instance = Instance::get_local().expect("Failed to get local instance");
|
||||||
let email = format!("{}@{}", LOCAL_INSTANCE_USERNAME, &instance.public_domain);
|
let email = format!("{}@{}", LOCAL_INSTANCE_USERNAME, &instance.public_domain);
|
||||||
NewUser::new_local(
|
NewUser::new_local(
|
||||||
|
@ -102,6 +93,17 @@ impl Instance {
|
||||||
None,
|
None,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn get_local_instance_user() -> Option<&'static User> {
|
||||||
|
LOCAL_INSTANCE_USER.get()
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn get_local_instance_user_uncached(conn: &Connection) -> Result<User> {
|
||||||
|
users::table
|
||||||
|
.filter(users::role.eq(3))
|
||||||
|
.first(conn)
|
||||||
|
.or_else(|err| match err {
|
||||||
|
NotFound => Self::create_local_instance_user(conn),
|
||||||
_ => Err(Error::Db(err)),
|
_ => Err(Error::Db(err)),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue