use crate::PerformCrud;
use actix_web::web::Data;
use lemmy_api_common::{
- blocking,
- build_federated_instances,
- get_local_user_settings_view_from_jwt_opt,
person::Register,
- site::*,
+ site::{CreateSite, GetSite, GetSiteResponse, MyUserInfo},
+ utils::{blocking, build_federated_instances, get_local_user_settings_view_from_jwt_opt},
};
-use lemmy_db_views::site_view::SiteView;
-use lemmy_db_views_actor::{
- community_block_view::CommunityBlockView,
- community_follower_view::CommunityFollowerView,
- community_moderator_view::CommunityModeratorView,
- person_block_view::PersonBlockView,
- person_view::PersonViewSafe,
+use lemmy_db_schema::source::{actor_language::SiteLanguage, language::Language};
+use lemmy_db_views::structs::{LocalUserDiscussionLanguageView, SiteView};
+use lemmy_db_views_actor::structs::{
+ CommunityBlockView,
+ CommunityFollowerView,
+ CommunityModeratorView,
+ PersonBlockView,
+ PersonViewSafe,
};
-use lemmy_utils::{version, ConnectionId, LemmyError};
+use lemmy_utils::{error::LemmyError, version, ConnectionId};
use lemmy_websocket::{messages::GetUsersOnline, LemmyContext};
use tracing::info;
let create_site = CreateSite {
name: setup.site_name.to_owned(),
- sidebar: setup.sidebar.to_owned(),
- description: setup.description.to_owned(),
- icon: setup.icon.to_owned(),
- banner: setup.banner.to_owned(),
- enable_downvotes: setup.enable_downvotes,
- open_registration: setup.open_registration,
- enable_nsfw: setup.enable_nsfw,
- community_creation_admin_only: setup.community_creation_admin_only,
- require_email_verification: setup.require_email_verification,
- require_application: setup.require_application,
- application_question: setup.application_question.to_owned(),
- private_instance: setup.private_instance,
- default_theme: setup.default_theme.to_owned(),
auth: admin_jwt,
+ ..CreateSite::default()
};
create_site.perform(context, websocket_id).await?;
info!("Site {} created", setup.site_name);
.await?
{
let person_id = local_user_view.person.id;
+ let local_user_id = local_user_view.local_user.id;
+
let follows = blocking(context.pool(), move |conn| {
CommunityFollowerView::for_person(conn, person_id)
})
.await?
.map_err(|e| LemmyError::from_error_message(e, "system_err_login"))?;
+ let discussion_languages = blocking(context.pool(), move |conn| {
+ LocalUserDiscussionLanguageView::read_languages(conn, local_user_id)
+ })
+ .await?
+ .map_err(|e| LemmyError::from_error_message(e, "system_err_login"))?;
+
Some(MyUserInfo {
local_user_view,
follows,
moderates,
community_blocks,
person_blocks,
+ discussion_languages,
})
} else {
None
};
- let federated_instances = build_federated_instances(
- context.pool(),
- &context.settings().federation,
- &context.settings().hostname,
- )
- .await?;
+ let federated_instances = build_federated_instances(context.pool(), context.settings()).await?;
+
+ let all_languages = blocking(context.pool(), Language::read_all).await??;
+ let discussion_languages = blocking(context.pool(), SiteLanguage::read_local).await??;
Ok(GetSiteResponse {
site_view,
version: version::VERSION.to_string(),
my_user,
federated_instances,
+ all_languages,
+ discussion_languages,
})
}
}