1
0
mirror of https://github.com/osmarks/mycorrhiza.git synced 2025-01-07 18:30:26 +00:00

Initial user panel draft

This commit is contained in:
handlerug 2021-06-29 17:34:36 +07:00
parent 16861bd3d4
commit 477c449a05
No known key found for this signature in database
GPG Key ID: 38009F0605051491
8 changed files with 175 additions and 5 deletions

View File

@ -2,14 +2,14 @@ package user
import ( import (
"encoding/json" "encoding/json"
"golang.org/x/crypto/bcrypt"
"io/ioutil" "io/ioutil"
"log" "log"
"os" "os"
"golang.org/x/crypto/bcrypt"
"github.com/bouncepaw/mycorrhiza/cfg" "github.com/bouncepaw/mycorrhiza/cfg"
"github.com/bouncepaw/mycorrhiza/util"
"github.com/bouncepaw/mycorrhiza/files" "github.com/bouncepaw/mycorrhiza/files"
"github.com/bouncepaw/mycorrhiza/util"
) )
// InitUserDatabase checks the configuration for auth methods and loads users // InitUserDatabase checks the configuration for auth methods and loads users

View File

@ -58,6 +58,7 @@ func Register(username, password string) error {
Name: username, Name: username,
Group: "editor", Group: "editor",
HashedPassword: string(hash), HashedPassword: string(hash),
RegisteredAt: time.Now(),
Source: SourceRegistration, Source: SourceRegistration,
} }
users.Store(username, &u) users.Store(username, &u)

View File

@ -2,6 +2,7 @@ package user
import ( import (
"sync" "sync"
"time"
"golang.org/x/crypto/bcrypt" "golang.org/x/crypto/bcrypt"
) )
@ -24,6 +25,7 @@ type User struct {
Group string `json:"group"` Group string `json:"group"`
Password string `json:"password"` // for fixed Password string `json:"password"` // for fixed
HashedPassword string `json:"hashed_password"` // for registered HashedPassword string `json:"hashed_password"` // for registered
RegisteredAt time.Time `json:"registered_on"`
Source UserSource `json:"-"` Source UserSource `json:"-"`
sync.RWMutex sync.RWMutex

34
views/admin.qtpl Normal file
View File

@ -0,0 +1,34 @@
{% import "github.com/bouncepaw/mycorrhiza/user" %}
{% func AdminUsersPanelHTML(userList []*user.User) %}
<div class="layout">
<main class="main-width">
<h1>Manage users</h1>
<form action="/admin/reindex-users" method="get">
<button class="btn btn_accent" type="submit">Reindex users</button>
</form>
<h2>Users list</h2>
<table>
<thead>
<tr>
<th>Name</th>
<th>Group</th>
<th>Registered at</th>
</tr>
</thead>
<tbody>
{% for _, u := range userList %}
<tr>
<td>{%s= u.Name %}</td>
<td>{%s= u.Group %}</td>
<td>{%s= u.RegisteredAt.Format("2006-01-02 15:04:05-0700") %}</td>
</tr>
{% endfor %}
</tbody>
</table>
</main>
</div>
{% endfunc %}

105
views/admin.qtpl.go Normal file
View File

@ -0,0 +1,105 @@
// Code generated by qtc from "admin.qtpl". DO NOT EDIT.
// See https://github.com/valyala/quicktemplate for details.
//line views/admin.qtpl:1
package views
//line views/admin.qtpl:1
import "github.com/bouncepaw/mycorrhiza/user"
//line views/admin.qtpl:3
import (
qtio422016 "io"
qt422016 "github.com/valyala/quicktemplate"
)
//line views/admin.qtpl:3
var (
_ = qtio422016.Copy
_ = qt422016.AcquireByteBuffer
)
//line views/admin.qtpl:3
func StreamAdminUsersPanelHTML(qw422016 *qt422016.Writer, userList []*user.User) {
//line views/admin.qtpl:3
qw422016.N().S(`
<div class="layout">
<main class="main-width">
<h1>Manage users</h1>
<form action="/admin/reindex-users" method="get">
<button class="btn btn_accent" type="submit">Reindex users</button>
</form>
<h2>Users list</h2>
<table>
<thead>
<tr>
<th>Name</th>
<th>Group</th>
<th>Registered at</th>
</tr>
</thead>
<tbody>
`)
//line views/admin.qtpl:23
for _, u := range userList {
//line views/admin.qtpl:23
qw422016.N().S(`
<tr>
<td>`)
//line views/admin.qtpl:25
qw422016.N().S(u.Name)
//line views/admin.qtpl:25
qw422016.N().S(`</td>
<td>`)
//line views/admin.qtpl:26
qw422016.N().S(u.Group)
//line views/admin.qtpl:26
qw422016.N().S(`</td>
<td>`)
//line views/admin.qtpl:27
qw422016.N().S(u.RegisteredAt.Format("2006-01-02 15:04:05-0700"))
//line views/admin.qtpl:27
qw422016.N().S(`</td>
</tr>
`)
//line views/admin.qtpl:29
}
//line views/admin.qtpl:29
qw422016.N().S(`
</tbody>
</table>
</main>
</div>
`)
//line views/admin.qtpl:34
}
//line views/admin.qtpl:34
func WriteAdminUsersPanelHTML(qq422016 qtio422016.Writer, userList []*user.User) {
//line views/admin.qtpl:34
qw422016 := qt422016.AcquireWriter(qq422016)
//line views/admin.qtpl:34
StreamAdminUsersPanelHTML(qw422016, userList)
//line views/admin.qtpl:34
qt422016.ReleaseWriter(qw422016)
//line views/admin.qtpl:34
}
//line views/admin.qtpl:34
func AdminUsersPanelHTML(userList []*user.User) string {
//line views/admin.qtpl:34
qb422016 := qt422016.AcquireByteBuffer()
//line views/admin.qtpl:34
WriteAdminUsersPanelHTML(qb422016, userList)
//line views/admin.qtpl:34
qs422016 := string(qb422016.B)
//line views/admin.qtpl:34
qt422016.ReleaseByteBuffer(qb422016)
//line views/admin.qtpl:34
return qs422016
//line views/admin.qtpl:34
}

View File

@ -137,7 +137,7 @@ for u := range user.YieldUsers() {
<section> <section>
<h2>Safe things</h2> <h2>Safe things</h2>
<ul> <ul>
<li><a href="/about">About this wiki<a></li> <li><a href="/about">About this wiki</a></li>
<li><a href="/user-list">User list</a></li> <li><a href="/user-list">User list</a></li>
<li><a href="/update-header-links">Update header links</a></li> <li><a href="/update-header-links">Update header links</a></li>
</ul> </ul>
@ -171,4 +171,4 @@ for u := range user.YieldUsers() {
{% for _, scriptPath := range cfg.OmnipresentScripts %} {% for _, scriptPath := range cfg.OmnipresentScripts %}
<script src="{%s scriptPath %}"></script> <script src="{%s scriptPath %}"></script>
{% endfor %} {% endfor %}
{% endfunc %} {% endfunc %}

View File

@ -470,7 +470,7 @@ func StreamAdminPanelHTML(qw422016 *qt422016.Writer) {
<section> <section>
<h2>Safe things</h2> <h2>Safe things</h2>
<ul> <ul>
<li><a href="/about">About this wiki<a></li> <li><a href="/about">About this wiki</a></li>
<li><a href="/user-list">User list</a></li> <li><a href="/user-list">User list</a></li>
<li><a href="/update-header-links">Update header links</a></li> <li><a href="/update-header-links">Update header links</a></li>
</ul> </ul>

View File

@ -4,6 +4,7 @@ import (
"io" "io"
"log" "log"
"net/http" "net/http"
"sort"
"github.com/bouncepaw/mycorrhiza/cfg" "github.com/bouncepaw/mycorrhiza/cfg"
"github.com/bouncepaw/mycorrhiza/user" "github.com/bouncepaw/mycorrhiza/user"
@ -17,6 +18,8 @@ func initAdmin() {
http.HandleFunc("/admin", handlerAdmin) http.HandleFunc("/admin", handlerAdmin)
http.HandleFunc("/admin/shutdown", handlerAdminShutdown) http.HandleFunc("/admin/shutdown", handlerAdminShutdown)
http.HandleFunc("/admin/reindex-users", handlerAdminReindexUsers) http.HandleFunc("/admin/reindex-users", handlerAdminReindexUsers)
http.HandleFunc("/admin/users", handlerAdminUsers)
} }
} }
@ -49,3 +52,28 @@ func handlerAdminReindexUsers(w http.ResponseWriter, rq *http.Request) {
http.Redirect(w, rq, "/hypha/"+cfg.UserHypha, http.StatusSeeOther) http.Redirect(w, rq, "/hypha/"+cfg.UserHypha, http.StatusSeeOther)
} }
} }
func handlerAdminUsers(w http.ResponseWriter, r *http.Request) {
util.PrepareRq(r)
if user.CanProceed(r, "admin") {
// Get a sorted list of users
var userList []*user.User
for u := range user.YieldUsers() {
userList = append(userList, u)
}
sort.Slice(userList, func(i, j int) bool {
less := userList[i].RegisteredAt.Before(userList[j].RegisteredAt)
return less
})
html := views.AdminUsersPanelHTML(userList)
html = views.BaseHTML("Manage users", html, user.FromRequest(r))
w.Header().Set("Content-Type", "text/html; charset=utf-8")
_, err := io.WriteString(w, html)
if err != nil {
log.Println(err)
}
}
}