summaryrefslogtreecommitdiff
path: root/internal/api/client/filters
diff options
context:
space:
mode:
authorLibravatar tobi <31960611+tsmethurst@users.noreply.github.com>2024-11-05 13:29:51 +0100
committerLibravatar GitHub <noreply@github.com>2024-11-05 13:29:51 +0100
commite953d80dff4298bccb4bc96e80e2a0e5831936f5 (patch)
tree4ba7e950c58d105fc04ff2b7b53753475cf06413 /internal/api/client/filters
parentpreviously we were using the ffmpeg runner for ffprobe :facepalm: (#3512) (diff)
downloadgotosocial-e953d80dff4298bccb4bc96e80e2a0e5831936f5.tar.xz
[bugfix] Fix setting immediate `expires_at` value on filter endpoints (#3513)v0.17.2
* [bugfix] Fix setting immediate `expires_at` value on filter endpoints * update wording * update wording * oh my
Diffstat (limited to 'internal/api/client/filters')
-rw-r--r--internal/api/client/filters/v1/validate.go39
-rw-r--r--internal/api/client/filters/v2/filterpost.go34
-rw-r--r--internal/api/client/filters/v2/filterput.go34
3 files changed, 48 insertions, 59 deletions
diff --git a/internal/api/client/filters/v1/validate.go b/internal/api/client/filters/v1/validate.go
index cce00fdc4..9e876c8cf 100644
--- a/internal/api/client/filters/v1/validate.go
+++ b/internal/api/client/filters/v1/validate.go
@@ -19,15 +19,14 @@ package v1
import (
"errors"
- "fmt"
- "strconv"
- "github.com/superseriousbusiness/gotosocial/internal/api/model"
+ apimodel "github.com/superseriousbusiness/gotosocial/internal/api/model"
+ apiutil "github.com/superseriousbusiness/gotosocial/internal/api/util"
"github.com/superseriousbusiness/gotosocial/internal/util"
"github.com/superseriousbusiness/gotosocial/internal/validate"
)
-func validateNormalizeCreateUpdateFilter(form *model.FilterCreateUpdateRequestV1) error {
+func validateNormalizeCreateUpdateFilter(form *apimodel.FilterCreateUpdateRequestV1) error {
if err := validate.FilterKeyword(form.Phrase); err != nil {
return err
}
@@ -48,25 +47,23 @@ func validateNormalizeCreateUpdateFilter(form *model.FilterCreateUpdateRequestV1
}
// 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)
+ if form.ExpiresInI != nil {
+ // If we parsed this as JSON, expires_in
+ // may be either a float64 or a string.
+ var err error
+ form.ExpiresIn, err = apiutil.ParseDuration(
+ form.ExpiresInI,
+ "expires_in",
+ )
+ if err != nil {
+ return err
}
}
+ // Interpret zero as indefinite duration.
+ if form.ExpiresIn != nil && *form.ExpiresIn == 0 {
+ form.ExpiresIn = nil
+ }
+
return nil
}
diff --git a/internal/api/client/filters/v2/filterpost.go b/internal/api/client/filters/v2/filterpost.go
index 13270b1e5..632c4402f 100644
--- a/internal/api/client/filters/v2/filterpost.go
+++ b/internal/api/client/filters/v2/filterpost.go
@@ -18,9 +18,7 @@
package v2
import (
- "fmt"
"net/http"
- "strconv"
"github.com/gin-gonic/gin"
apimodel "github.com/superseriousbusiness/gotosocial/internal/api/model"
@@ -228,26 +226,24 @@ func validateNormalizeCreateFilter(form *apimodel.FilterCreateRequestV2) error {
form.FilterAction = util.Ptr(action)
// 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)
+ if form.ExpiresInI != nil {
+ // If we parsed this as JSON, expires_in
+ // may be either a float64 or a string.
+ var err error
+ form.ExpiresIn, err = apiutil.ParseDuration(
+ form.ExpiresInI,
+ "expires_in",
+ )
+ if err != nil {
+ return err
}
}
+ // Interpret zero as indefinite duration.
+ if form.ExpiresIn != nil && *form.ExpiresIn == 0 {
+ form.ExpiresIn = nil
+ }
+
// Normalize and validate new keywords and statuses.
for i, formKeyword := range form.Keywords {
if err := validate.FilterKeyword(formKeyword.Keyword); err != nil {
diff --git a/internal/api/client/filters/v2/filterput.go b/internal/api/client/filters/v2/filterput.go
index 24f7e7567..cde03360d 100644
--- a/internal/api/client/filters/v2/filterput.go
+++ b/internal/api/client/filters/v2/filterput.go
@@ -19,9 +19,7 @@ package v2
import (
"errors"
- "fmt"
"net/http"
- "strconv"
"github.com/gin-gonic/gin"
apimodel "github.com/superseriousbusiness/gotosocial/internal/api/model"
@@ -272,26 +270,24 @@ func validateNormalizeUpdateFilter(form *apimodel.FilterUpdateRequestV2) error {
}
// 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)
+ if form.ExpiresInI != nil {
+ // If we parsed this as JSON, expires_in
+ // may be either a float64 or a string.
+ var err error
+ form.ExpiresIn, err = apiutil.ParseDuration(
+ form.ExpiresInI,
+ "expires_in",
+ )
+ if err != nil {
+ return err
}
}
+ // Interpret zero as indefinite duration.
+ if form.ExpiresIn != nil && *form.ExpiresIn == 0 {
+ form.ExpiresIn = nil
+ }
+
// Normalize and validate updates.
for i, formKeyword := range form.Keywords {
if formKeyword.Keyword != nil {