mirror of
https://github.com/jech/galene.git
synced 2024-11-22 00:25:58 +01:00
Rework permissions formatting in galenectl.
This commit is contained in:
parent
7fe6a5da91
commit
8de77fe417
2 changed files with 54 additions and 1 deletions
|
@ -681,6 +681,29 @@ func parsePermissions(p string, expand bool) (any, error) {
|
||||||
return pp.Permissions(nil), nil
|
return pp.Permissions(nil), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func formatRawPermissions(permissions []string) string {
|
||||||
|
var perms []byte
|
||||||
|
for _, p := range permissions {
|
||||||
|
if len(p) > 0 {
|
||||||
|
perms = append(perms, p[0])
|
||||||
|
} else {
|
||||||
|
perms = append(perms, '?')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
sort.Slice(perms, func(i, j int) bool {
|
||||||
|
return perms[i] < perms[j]
|
||||||
|
})
|
||||||
|
return fmt.Sprintf("[%s]", perms)
|
||||||
|
}
|
||||||
|
|
||||||
|
func formatPermissions(permissions group.Permissions) string {
|
||||||
|
s := permissions.String()
|
||||||
|
if len(s) > 0 && s[0] != '[' {
|
||||||
|
return s
|
||||||
|
}
|
||||||
|
return formatRawPermissions(permissions.Permissions(nil))
|
||||||
|
}
|
||||||
|
|
||||||
func listUsersCmd(cmdname string, args []string) {
|
func listUsersCmd(cmdname string, args []string) {
|
||||||
var groupname string
|
var groupname string
|
||||||
var long bool
|
var long bool
|
||||||
|
@ -732,7 +755,9 @@ func listUsersCmd(cmdname string, args []string) {
|
||||||
fmt.Printf("%-12s (ERROR=%v)\n", user, err)
|
fmt.Printf("%-12s (ERROR=%v)\n", user, err)
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
fmt.Printf("%-12s %v\n", user, d.Permissions)
|
fmt.Printf("%-12s %v\n",
|
||||||
|
user, formatPermissions(d.Permissions),
|
||||||
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"encoding/json"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/jech/galene/group"
|
"github.com/jech/galene/group"
|
||||||
|
@ -38,3 +39,30 @@ func TestMakePassword(t *testing.T) {
|
||||||
t.Errorf("Wildcard didn't match")
|
t.Errorf("Wildcard didn't match")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestFormatPermissions(t *testing.T) {
|
||||||
|
tests := []struct{ j, v, p string }{
|
||||||
|
{`"op"`, "op", "[mopt]"},
|
||||||
|
{`"present"`, "present", "[mp]"},
|
||||||
|
{`"observe"`, "observe", "[]"},
|
||||||
|
{`"admin"`, "admin", "[a]"},
|
||||||
|
{`["message", "present", "token"]`, "[mpt]", "[mpt]"},
|
||||||
|
{`[]`, "[]", "[]"},
|
||||||
|
}
|
||||||
|
for _, test := range tests {
|
||||||
|
var p group.Permissions
|
||||||
|
err := json.Unmarshal([]byte(test.j), &p)
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Unmarshal %#v: %v", test.j, err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
v := formatPermissions(p)
|
||||||
|
if v != test.v {
|
||||||
|
t.Errorf("Expected %v, got %v", test.v, v)
|
||||||
|
}
|
||||||
|
pp := formatRawPermissions(p.Permissions(nil))
|
||||||
|
if pp != test.p {
|
||||||
|
t.Errorf("Expected %v, got %v", test.p, pp)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue