summaryrefslogtreecommitdiff
path: root/internal/visibility/filter.go
diff options
context:
space:
mode:
authorLibravatar Tobi Smethurst <31960611+tsmethurst@users.noreply.github.com>2021-06-17 18:02:33 +0200
committerLibravatar GitHub <noreply@github.com>2021-06-17 18:02:33 +0200
commit82d9f88e424fffacfa9a9c1c26f2f702b97f3e3a (patch)
tree60379f8eb809e9019222f67a13b547e4a26bfc83 /internal/visibility/filter.go
parentTimeline manager (#40) (diff)
downloadgotosocial-82d9f88e424fffacfa9a9c1c26f2f702b97f3e3a.tar.xz
Timeline improvements (#41)
Tidying up. Parent/child statuses now display correctly in status/id/context.
Diffstat (limited to 'internal/visibility/filter.go')
-rw-r--r--internal/visibility/filter.go33
1 files changed, 33 insertions, 0 deletions
diff --git a/internal/visibility/filter.go b/internal/visibility/filter.go
new file mode 100644
index 000000000..d12ad0ff6
--- /dev/null
+++ b/internal/visibility/filter.go
@@ -0,0 +1,33 @@
+package visibility
+
+import (
+ "github.com/sirupsen/logrus"
+ "github.com/superseriousbusiness/gotosocial/internal/db"
+ "github.com/superseriousbusiness/gotosocial/internal/gtsmodel"
+)
+
+// Filter packages up a bunch of logic for checking whether given statuses or accounts are visible to a requester.
+type Filter interface {
+ // StatusVisible returns true if targetStatus is visible to requestingAccount, based on the
+ // privacy settings of the status, and any blocks/mutes that might exist between the two accounts
+ // or account domains, and other relevant accounts mentioned in or replied to by the status.
+ StatusVisible(targetStatus *gtsmodel.Status, requestingAccount *gtsmodel.Account) (bool, error)
+
+ // StatusHometimelineable returns true if targetStatus should be in the home timeline of the requesting account.
+ //
+ // This function will call StatusVisible internally, so it's not necessary to call it beforehand.
+ StatusHometimelineable(targetStatus *gtsmodel.Status, requestingAccount *gtsmodel.Account) (bool, error)
+}
+
+type filter struct {
+ db db.DB
+ log *logrus.Logger
+}
+
+// NewFilter returns a new Filter interface that will use the provided database and logger.
+func NewFilter(db db.DB, log *logrus.Logger) Filter {
+ return &filter{
+ db: db,
+ log: log,
+ }
+}