fix: respect likes privacy, default to show remote

we don't get likes we're not supposed to know of anyway, so we can
assume remote users are ok with us showing these things they liked?
This commit is contained in:
əlemi 2024-12-27 01:45:22 +01:00
parent b1cf349805
commit 7befb83dcd
Signed by: alemi
GPG key ID: A4895B84D311642C

View file

@ -1,7 +1,7 @@
use axum::extract::{Path, Query, State}; use axum::extract::{Path, Query, State};
use sea_orm::{ColumnTrait, QueryFilter, QueryOrder, QuerySelect, RelationTrait}; use sea_orm::{ColumnTrait, QueryFilter, QueryOrder, QuerySelect, RelationTrait};
use upub::{model, selector::{RichObject, BatchFillable}, Context}; use upub::{model, selector::{RichFillable, RichObject}, Context};
use crate::{activitypub::Pagination, builders::JsonLD, ApiError, AuthIdentity}; use crate::{activitypub::Pagination, builders::JsonLD, ApiError, AuthIdentity};
@ -9,7 +9,7 @@ pub async fn get(
State(ctx): State<Context>, State(ctx): State<Context>,
Path(id): Path<String>, Path(id): Path<String>,
) -> crate::ApiResult<JsonLD<serde_json::Value>> { ) -> crate::ApiResult<JsonLD<serde_json::Value>> {
crate::builders::collection(upub::url!(ctx, "/actors/{id}/liked"), None) crate::builders::collection(upub::url!(ctx, "/actors/{id}/likes"), None)
} }
pub async fn page( pub async fn page(
@ -25,15 +25,16 @@ pub async fn page(
.await? .await?
.ok_or_else(ApiError::not_found)?; .ok_or_else(ApiError::not_found)?;
if !auth.is(&uid) && !config.map_or(false, |x| x.show_liked_objects) { if !auth.is(&uid) && !config.map_or(true, |x| x.show_liked_objects) {
return Err(ApiError::forbidden()); return Err(ApiError::forbidden());
} }
let (limit, offset) = page.pagination(); let (limit, offset) = page.pagination();
let items : Vec<serde_json::Value> = upub::Query::objects(auth.my_id(), true) let items : Vec<serde_json::Value> = upub::Query::objects(auth.my_id(), true)
.join(sea_orm::JoinType::InnerJoin, upub::model::object::Relation::Likes.def()) .join(sea_orm::JoinType::InnerJoin, upub::model::like::Relation::Objects.def())
.filter(auth.filter_objects()) .join(sea_orm::JoinType::InnerJoin, upub::model::activity::Relation::Likes.def())
.filter(auth.filter_activities())
.filter(upub::model::like::Column::Actor.eq(user.internal)) .filter(upub::model::like::Column::Actor.eq(user.internal))
.order_by_desc(upub::model::like::Column::Published) .order_by_desc(upub::model::like::Column::Published)
.limit(limit) .limit(limit)
@ -41,15 +42,11 @@ pub async fn page(
.into_model::<RichObject>() .into_model::<RichObject>()
.all(ctx.db()) .all(ctx.db())
.await? .await?
.with_batched::<upub::model::attachment::Entity>(ctx.db()) .load_batched_models(ctx.db())
.await?
.with_batched::<upub::model::mention::Entity>(ctx.db())
.await?
.with_batched::<upub::model::hashtag::Entity>(ctx.db())
.await? .await?
.into_iter() .into_iter()
.map(|x| ctx.ap(x)) .map(|x| ctx.ap(x))
.collect(); .collect();
crate::builders::collection_page(&upub::url!(ctx, "/actors/{id}/outbox/page"), page, apb::Node::array(items)) crate::builders::collection_page(&upub::url!(ctx, "/actors/{id}/likes/page"), page, apb::Node::array(items))
} }