summaryrefslogtreecommitdiff
path: root/internal/visibility/statusboostable.go
diff options
context:
space:
mode:
Diffstat (limited to 'internal/visibility/statusboostable.go')
-rw-r--r--internal/visibility/statusboostable.go60
1 files changed, 0 insertions, 60 deletions
diff --git a/internal/visibility/statusboostable.go b/internal/visibility/statusboostable.go
deleted file mode 100644
index e008008c2..000000000
--- a/internal/visibility/statusboostable.go
+++ /dev/null
@@ -1,60 +0,0 @@
-// GoToSocial
-// Copyright (C) GoToSocial Authors admin@gotosocial.org
-// SPDX-License-Identifier: AGPL-3.0-or-later
-//
-// This program is free software: you can redistribute it and/or modify
-// it under the terms of the GNU Affero General Public License as published by
-// the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU Affero General Public License for more details.
-//
-// You should have received a copy of the GNU Affero General Public License
-// along with this program. If not, see <http://www.gnu.org/licenses/>.
-
-package visibility
-
-import (
- "context"
- "errors"
- "fmt"
-
- "github.com/superseriousbusiness/gotosocial/internal/gtsmodel"
- "github.com/superseriousbusiness/gotosocial/internal/log"
-)
-
-func (f *filter) StatusBoostable(ctx context.Context, targetStatus *gtsmodel.Status, requestingAccount *gtsmodel.Account) (bool, error) {
- // if the status isn't visible, it certainly isn't boostable
- visible, err := f.StatusVisible(ctx, targetStatus, requestingAccount)
- if err != nil {
- return false, fmt.Errorf("error seeing if status %s is visible: %s", targetStatus.ID, err)
- }
- if !visible {
- return false, errors.New("status is not visible")
- }
-
- // direct messages are never boostable, even if they're visible
- if targetStatus.Visibility == gtsmodel.VisibilityDirect {
- log.Trace(ctx, "status is not boostable because it is a DM")
- return false, nil
- }
-
- // the original account should always be able to boost its own non-DM statuses
- if requestingAccount.ID == targetStatus.Account.ID {
- log.Trace(ctx, "status is boostable because author is booster")
- return true, nil
- }
-
- // if status is followers-only and not the author's, it is not boostable
- if targetStatus.Visibility == gtsmodel.VisibilityFollowersOnly {
- log.Trace(ctx, "status not boostable because it is followers-only")
- return false, nil
- }
-
- // otherwise, status is as boostable as it says it is
- log.Trace(ctx, "defaulting to status.boostable value")
- return *targetStatus.Boostable, nil
-}