mirror of
https://github.com/superseriousbusiness/gotosocial.git
synced 2024-07-01 19:40:33 +00:00
61a2b91f45
* Implement client-side v1 filters * Exclude linter false positives * Update test/envparsing.sh * Fix minor Swagger, style, and Bun usage issues * Regenerate Swagger * De-generify filter keywords * Remove updating filter statuses This is an operation that the Mastodon v2 filter API doesn't actually have, because filter statuses, unlike keywords, don't have options: the only info they contain is the status ID to be filtered. * Add a test for filter statuses specifically * De-generify filter statuses * Inline FilterEntry * Use vertical style for Bun operations consistently * Add comment on Filter DB interface * Remove GoLand linter control comments Our existing linters should catch these, or they don't matter very much * Reduce memory ratio for filters
69 lines
2.1 KiB
Go
69 lines
2.1 KiB
Go
// 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 v1
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
"strconv"
|
|
|
|
"github.com/superseriousbusiness/gotosocial/internal/api/model"
|
|
"github.com/superseriousbusiness/gotosocial/internal/util"
|
|
"github.com/superseriousbusiness/gotosocial/internal/validate"
|
|
)
|
|
|
|
func validateNormalizeCreateUpdateFilter(form *model.FilterCreateUpdateRequestV1) error {
|
|
if err := validate.FilterKeyword(form.Phrase); err != nil {
|
|
return err
|
|
}
|
|
if err := validate.FilterContexts(form.Context); err != nil {
|
|
return err
|
|
}
|
|
|
|
// Apply defaults for missing fields.
|
|
form.WholeWord = util.Ptr(util.PtrValueOr(form.WholeWord, false))
|
|
form.Irreversible = util.Ptr(util.PtrValueOr(form.Irreversible, false))
|
|
|
|
if *form.Irreversible {
|
|
return errors.New("irreversible aka server-side drop filters are not supported yet")
|
|
}
|
|
|
|
// Normalize filter expiry if necessary.
|
|
// If we parsed this as JSON, expires_in
|
|
// may be either a float64 or a string.
|
|
if ei := form.ExpiresInI; ei != nil {
|
|
switch e := ei.(type) {
|
|
case float64:
|
|
form.ExpiresIn = util.Ptr(int(e))
|
|
|
|
case string:
|
|
expiresIn, err := strconv.Atoi(e)
|
|
if err != nil {
|
|
return fmt.Errorf("could not parse expires_in value %s as integer: %w", e, err)
|
|
}
|
|
|
|
form.ExpiresIn = &expiresIn
|
|
|
|
default:
|
|
return fmt.Errorf("could not parse expires_in type %T as integer", ei)
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|