mirror of
https://github.com/LemmyNet/lemmy.git
synced 2025-01-22 06:01:09 +00:00
Fix local site images. (#2519)
* Fix local site images. * It should be set up.
This commit is contained in:
parent
7aa6d6b3e1
commit
ed9e91345a
|
@ -12,7 +12,7 @@ use actix_web::{
|
|||
};
|
||||
use futures::stream::{Stream, StreamExt};
|
||||
use lemmy_api_common::utils::{blocking, get_local_user_view_from_jwt};
|
||||
use lemmy_db_schema::source::site::Site;
|
||||
use lemmy_db_schema::source::local_site::LocalSite;
|
||||
use lemmy_utils::{claims::Claims, rate_limit::RateLimit, REQWEST_TIMEOUT};
|
||||
use lemmy_websocket::LemmyContext;
|
||||
use reqwest::Body;
|
||||
|
@ -126,20 +126,20 @@ async fn full_res(
|
|||
context: web::Data<LemmyContext>,
|
||||
) -> Result<HttpResponse, Error> {
|
||||
// block access to images if instance is private and unauthorized, public
|
||||
let site = blocking(context.pool(), Site::read_local_site).await?;
|
||||
let local_site = blocking(context.pool(), LocalSite::read)
|
||||
.await?
|
||||
.map_err(error::ErrorBadRequest)?;
|
||||
// The site might not be set up yet
|
||||
if let Ok(site) = site {
|
||||
if site.private_instance {
|
||||
let jwt = req
|
||||
.cookie("jwt")
|
||||
.expect("No auth header for picture access");
|
||||
if get_local_user_view_from_jwt(jwt.value(), context.pool(), context.secret())
|
||||
.await
|
||||
.is_err()
|
||||
{
|
||||
return Ok(HttpResponse::Unauthorized().finish());
|
||||
};
|
||||
}
|
||||
if local_site.private_instance {
|
||||
let jwt = req
|
||||
.cookie("jwt")
|
||||
.expect("No auth header for picture access");
|
||||
if get_local_user_view_from_jwt(jwt.value(), context.pool(), context.secret())
|
||||
.await
|
||||
.is_err()
|
||||
{
|
||||
return Ok(HttpResponse::Unauthorized().finish());
|
||||
};
|
||||
}
|
||||
let name = &filename.into_inner();
|
||||
|
||||
|
|
Loading…
Reference in a new issue