summaryrefslogtreecommitdiffstats
path: root/modules/util
diff options
context:
space:
mode:
authorwxiaoguang <wxiaoguang@gmail.com>2021-10-13 02:11:35 +0800
committerGitHub <noreply@github.com>2021-10-12 20:11:35 +0200
commit7bcbdd07072d375eb9f24a64a047879ae2aa7aed (patch)
tree39ec57de914d4ccb05395ee991b94f6bca90dedb /modules/util
parentd0a681fbc3fb626adcddbbb13f8c96c0bbd72c02 (diff)
downloadgitea-7bcbdd07072d375eb9f24a64a047879ae2aa7aed.tar.gz
gitea-7bcbdd07072d375eb9f24a64a047879ae2aa7aed.zip
Add user status filter to admin user management page (#16770)
It makes Admin's life easier to filter users by various status. * introduce window.config.PageData to pass template data to javascript module and small refactor move legacy window.ActivityTopAuthors to window.config.PageData.ActivityTopAuthors make HTML structure more IDE-friendly in footer.tmpl and head.tmpl remove incorrect <style class="list-search-style"></style> in head.tmpl use log.Error instead of log.Critical in admin user search * use LEFT JOIN instead of SubQuery when admin filters users by 2fa. revert non-en locale. * use OptionalBool instead of status map * refactor SearchUserOptions.toConds to SearchUserOptions.toSearchQueryBase * add unit test for user search * only allow admin to use filters to search users
Diffstat (limited to 'modules/util')
-rw-r--r--modules/util/util.go12
-rw-r--r--modules/util/util_test.go13
2 files changed, 24 insertions, 1 deletions
diff --git a/modules/util/util.go b/modules/util/util.go
index d26e6f13e4..cbc6eb4f8a 100644
--- a/modules/util/util.go
+++ b/modules/util/util.go
@@ -9,6 +9,7 @@ import (
"crypto/rand"
"errors"
"math/big"
+ "strconv"
"strings"
)
@@ -17,7 +18,7 @@ type OptionalBool byte
const (
// OptionalBoolNone a "null" boolean value
- OptionalBoolNone = iota
+ OptionalBoolNone OptionalBool = iota
// OptionalBoolTrue a "true" boolean value
OptionalBoolTrue
// OptionalBoolFalse a "false" boolean value
@@ -47,6 +48,15 @@ func OptionalBoolOf(b bool) OptionalBool {
return OptionalBoolFalse
}
+// OptionalBoolParse get the corresponding OptionalBool of a string using strconv.ParseBool
+func OptionalBoolParse(s string) OptionalBool {
+ b, e := strconv.ParseBool(s)
+ if e != nil {
+ return OptionalBoolNone
+ }
+ return OptionalBoolOf(b)
+}
+
// Max max of two ints
func Max(a, b int) int {
if a < b {
diff --git a/modules/util/util_test.go b/modules/util/util_test.go
index f82671787c..39cf07c855 100644
--- a/modules/util/util_test.go
+++ b/modules/util/util_test.go
@@ -156,3 +156,16 @@ func Test_RandomString(t *testing.T) {
assert.NotEqual(t, str3, str4)
}
+
+func Test_OptionalBool(t *testing.T) {
+ assert.Equal(t, OptionalBoolNone, OptionalBoolParse(""))
+ assert.Equal(t, OptionalBoolNone, OptionalBoolParse("x"))
+
+ assert.Equal(t, OptionalBoolFalse, OptionalBoolParse("0"))
+ assert.Equal(t, OptionalBoolFalse, OptionalBoolParse("f"))
+ assert.Equal(t, OptionalBoolFalse, OptionalBoolParse("False"))
+
+ assert.Equal(t, OptionalBoolTrue, OptionalBoolParse("1"))
+ assert.Equal(t, OptionalBoolTrue, OptionalBoolParse("t"))
+ assert.Equal(t, OptionalBoolTrue, OptionalBoolParse("True"))
+}