✨ Complete friend visibility
This commit is contained in:
@@ -24,17 +24,23 @@ func FilterPostWithUserContext(tx *gorm.DB, user *models.Account) *gorm.DB {
|
||||
const (
|
||||
FriendsVisibility = models.PostVisibilityFriends
|
||||
SelectedVisibility = models.PostVisibilitySelected
|
||||
FilteredVisibility = models.PostVisibilityFiltered
|
||||
NoneVisibility = models.PostVisibilityNone
|
||||
)
|
||||
|
||||
// TODO Blocked by dealer, need support get friend list
|
||||
friends, _ := ListAccountFriends(*user)
|
||||
friendAllowList := lo.Map(friends, func(item models.Account, index int) uint {
|
||||
return item.ID
|
||||
})
|
||||
|
||||
tx = tx.Where(
|
||||
"(visibility != ? OR visibility != ? OR (visibility = ? AND ?) OR (visibility = ? AND NOT ?) OR author_id = ?)",
|
||||
FriendsVisibility,
|
||||
"(visibility != ? OR (visibility != ? AND author_id IN ?) OR (visibility = ? AND ?) OR (visibility = ? AND NOT ?) OR author_id = ?)",
|
||||
NoneVisibility,
|
||||
FriendsVisibility,
|
||||
friendAllowList,
|
||||
SelectedVisibility,
|
||||
datatypes.JSONQuery("visible_users").HasKey(strconv.Itoa(int(user.ID))),
|
||||
SelectedVisibility,
|
||||
FilteredVisibility,
|
||||
datatypes.JSONQuery("invisible_users").HasKey(strconv.Itoa(int(user.ID))),
|
||||
user.ID,
|
||||
)
|
||||
|
Reference in New Issue
Block a user