use diesel::{result::Error, *};
use lemmy_db_schema::{
aggregates::structs::SiteAggregates,
- schema::{site, site_aggregates},
- source::site::Site,
+ schema::{local_site, local_site_rate_limit, site, site_aggregates},
+ source::{local_site::LocalSite, local_site_rate_limit::LocalSiteRateLimit, site::Site},
};
impl SiteView {
- pub fn read_local(conn: &PgConnection) -> Result<Self, Error> {
- let (mut site, counts) = site::table
+ pub fn read_local(conn: &mut PgConnection) -> Result<Self, Error> {
+ let (mut site, local_site, local_site_rate_limit, counts) = site::table
+ .inner_join(local_site::table)
+ .inner_join(
+ local_site_rate_limit::table.on(local_site::id.eq(local_site_rate_limit::local_site_id)),
+ )
.inner_join(site_aggregates::table)
- .select((site::all_columns, site_aggregates::all_columns))
- .order_by(site::id)
- .first::<(Site, SiteAggregates)>(conn)?;
+ .select((
+ site::all_columns,
+ local_site::all_columns,
+ local_site_rate_limit::all_columns,
+ site_aggregates::all_columns,
+ ))
+ .first::<(Site, LocalSite, LocalSiteRateLimit, SiteAggregates)>(conn)?;
site.private_key = None;
- Ok(SiteView { site, counts })
+ Ok(SiteView {
+ site,
+ local_site,
+ local_site_rate_limit,
+ counts,
+ })
}
}