Skip to content

Commit f68d49c

Browse files
lunnyGusted
authored andcommitted
Move ParseBool to optional (go-gitea#33979)
(cherry picked from commit 25b6f38)
1 parent 9018e5b commit f68d49c

File tree

6 files changed

+31
-33
lines changed

6 files changed

+31
-33
lines changed

modules/optional/option.go

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -3,6 +3,8 @@
33

44
package optional
55

6+
import "strconv"
7+
68
type Option[T any] []T
79

810
func None[T any]() Option[T] {
@@ -43,3 +45,12 @@ func (o Option[T]) ValueOrDefault(v T) T {
4345
}
4446
return v
4547
}
48+
49+
// ParseBool get the corresponding optional.Option[bool] of a string using strconv.ParseBool
50+
func ParseBool(s string) Option[bool] {
51+
v, e := strconv.ParseBool(s)
52+
if e != nil {
53+
return None[bool]()
54+
}
55+
return Some(v)
56+
}

modules/optional/option_test.go

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -57,3 +57,16 @@ func TestOption(t *testing.T) {
5757
assert.True(t, opt3.Has())
5858
assert.Equal(t, int(1), opt3.Value())
5959
}
60+
61+
func Test_ParseBool(t *testing.T) {
62+
assert.Equal(t, optional.None[bool](), optional.ParseBool(""))
63+
assert.Equal(t, optional.None[bool](), optional.ParseBool("x"))
64+
65+
assert.Equal(t, optional.Some(false), optional.ParseBool("0"))
66+
assert.Equal(t, optional.Some(false), optional.ParseBool("f"))
67+
assert.Equal(t, optional.Some(false), optional.ParseBool("False"))
68+
69+
assert.Equal(t, optional.Some(true), optional.ParseBool("1"))
70+
assert.Equal(t, optional.Some(true), optional.ParseBool("t"))
71+
assert.Equal(t, optional.Some(true), optional.ParseBool("True"))
72+
}

modules/setting/setting.go

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -12,8 +12,8 @@ import (
1212
"time"
1313

1414
"forgejo.org/modules/log"
15+
"forgejo.org/modules/optional"
1516
"forgejo.org/modules/user"
16-
"forgejo.org/modules/util"
1717
)
1818

1919
var ForgejoVersion = "1.0.0"
@@ -162,7 +162,7 @@ func loadRunModeFrom(rootCfg ConfigProvider) {
162162
// The following is a purposefully undocumented option. Please do not run Forgejo as root. It will only cause future headaches.
163163
// Please don't use root as a bandaid to "fix" something that is broken, instead the broken thing should instead be fixed properly.
164164
unsafeAllowRunAsRoot := ConfigSectionKeyBool(rootSec, "I_AM_BEING_UNSAFE_RUNNING_AS_ROOT")
165-
unsafeAllowRunAsRoot = unsafeAllowRunAsRoot || util.OptionalBoolParse(os.Getenv("GITEA_I_AM_BEING_UNSAFE_RUNNING_AS_ROOT")).Value()
165+
unsafeAllowRunAsRoot = unsafeAllowRunAsRoot || optional.ParseBool(os.Getenv("GITEA_I_AM_BEING_UNSAFE_RUNNING_AS_ROOT")).Value()
166166
RunMode = os.Getenv("GITEA_RUN_MODE")
167167
if RunMode == "" {
168168
RunMode = rootSec.Key("RUN_MODE").MustString("prod")

modules/util/util.go

Lines changed: 0 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -14,22 +14,11 @@ import (
1414
"strconv"
1515
"strings"
1616

17-
"forgejo.org/modules/optional"
18-
1917
"golang.org/x/crypto/ssh"
2018
"golang.org/x/text/cases"
2119
"golang.org/x/text/language"
2220
)
2321

24-
// OptionalBoolParse get the corresponding optional.Option[bool] of a string using strconv.ParseBool
25-
func OptionalBoolParse(s string) optional.Option[bool] {
26-
v, e := strconv.ParseBool(s)
27-
if e != nil {
28-
return optional.None[bool]()
29-
}
30-
return optional.Some(v)
31-
}
32-
3322
// IsEmptyString checks if the provided string is empty
3423
func IsEmptyString(s string) bool {
3524
return len(strings.TrimSpace(s)) == 0

modules/util/util_test.go

Lines changed: 0 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -11,7 +11,6 @@ import (
1111
"strings"
1212
"testing"
1313

14-
"forgejo.org/modules/optional"
1514
"forgejo.org/modules/test"
1615
"forgejo.org/modules/util"
1716

@@ -181,19 +180,6 @@ func Test_RandomBytes(t *testing.T) {
181180
assert.NotEqual(t, bytes3, bytes4)
182181
}
183182

184-
func TestOptionalBoolParse(t *testing.T) {
185-
assert.Equal(t, optional.None[bool](), util.OptionalBoolParse(""))
186-
assert.Equal(t, optional.None[bool](), util.OptionalBoolParse("x"))
187-
188-
assert.Equal(t, optional.Some(false), util.OptionalBoolParse("0"))
189-
assert.Equal(t, optional.Some(false), util.OptionalBoolParse("f"))
190-
assert.Equal(t, optional.Some(false), util.OptionalBoolParse("False"))
191-
192-
assert.Equal(t, optional.Some(true), util.OptionalBoolParse("1"))
193-
assert.Equal(t, optional.Some(true), util.OptionalBoolParse("t"))
194-
assert.Equal(t, optional.Some(true), util.OptionalBoolParse("True"))
195-
}
196-
197183
// Test case for any function which accepts and returns a single string.
198184
type StringTest struct {
199185
in, out string

routers/web/admin/users.go

Lines changed: 5 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -22,7 +22,6 @@ import (
2222
"forgejo.org/modules/log"
2323
"forgejo.org/modules/optional"
2424
"forgejo.org/modules/setting"
25-
"forgejo.org/modules/util"
2625
"forgejo.org/modules/validation"
2726
"forgejo.org/modules/web"
2827
"forgejo.org/routers/web/explore"
@@ -77,11 +76,11 @@ func Users(ctx *context.Context) {
7776
PageSize: setting.UI.Admin.UserPagingNum,
7877
},
7978
SearchByEmail: true,
80-
IsActive: util.OptionalBoolParse(statusFilterMap["is_active"]),
81-
IsAdmin: util.OptionalBoolParse(statusFilterMap["is_admin"]),
82-
IsRestricted: util.OptionalBoolParse(statusFilterMap["is_restricted"]),
83-
IsTwoFactorEnabled: util.OptionalBoolParse(statusFilterMap["is_2fa_enabled"]),
84-
IsProhibitLogin: util.OptionalBoolParse(statusFilterMap["is_prohibit_login"]),
79+
IsActive: optional.ParseBool(statusFilterMap["is_active"]),
80+
IsAdmin: optional.ParseBool(statusFilterMap["is_admin"]),
81+
IsRestricted: optional.ParseBool(statusFilterMap["is_restricted"]),
82+
IsTwoFactorEnabled: optional.ParseBool(statusFilterMap["is_2fa_enabled"]),
83+
IsProhibitLogin: optional.ParseBool(statusFilterMap["is_prohibit_login"]),
8584
IncludeReserved: true, // administrator needs to list all accounts include reserved, bot, remote ones
8685
Load2FAStatus: true,
8786
ExtraParamStrings: extraParamStrings,

0 commit comments

Comments
 (0)