Add query function
This commit is contained in:
@@ -1,7 +1,7 @@
|
||||
package main
|
||||
|
||||
var SCRIPTS = map[string][]string{
|
||||
"balance assets": {"b", "assets", "-X", "$"},
|
||||
"register": {"r", "--tail", "10"},
|
||||
"balance this month": {"b", "-b", "this month"},
|
||||
var SCRIPTS = map[string]string{
|
||||
"balance assets": "b assets -X $",
|
||||
"register": "r --tail 10",
|
||||
"balance this month": "b -b \"this month\"",
|
||||
}
|
||||
|
||||
31
route.go
31
route.go
@@ -33,7 +33,7 @@ func router() *gin.Engine {
|
||||
authZone.GET("/dashboard", func(c *gin.Context) {
|
||||
HTML(c, 200, "dashboard.html", struct {
|
||||
Templates []*template.Template
|
||||
Scripts map[string][]string
|
||||
Scripts map[string]string
|
||||
}{
|
||||
ledgerTpl.Templates(),
|
||||
SCRIPTS,
|
||||
@@ -69,16 +69,6 @@ func router() *gin.Engine {
|
||||
}{tx})
|
||||
})
|
||||
|
||||
authZone.GET("/exec", func(c *gin.Context) {
|
||||
user := getUser(c)
|
||||
name, _ := c.GetQuery("name")
|
||||
if err := user.executeScript(c.Writer, name); err != nil {
|
||||
c.AbortWithError(500, err)
|
||||
log.Println(err)
|
||||
return
|
||||
}
|
||||
})
|
||||
|
||||
authZone.GET("/edit", func(c *gin.Context) {
|
||||
user := getUser(c)
|
||||
f, err := user.ReadFile(DEFAULT_JOURNAL)
|
||||
@@ -110,5 +100,24 @@ func router() *gin.Engine {
|
||||
c.FileAttachment(user.FilePath(DEFAULT_JOURNAL), DEFAULT_JOURNAL)
|
||||
})
|
||||
|
||||
authZone.GET("/query", func(c *gin.Context) {
|
||||
response := struct {
|
||||
Query string
|
||||
Result string
|
||||
Scripts map[string]string
|
||||
}{Scripts: SCRIPTS}
|
||||
user := getUser(c)
|
||||
var ok bool
|
||||
var err error
|
||||
response.Query, ok = c.GetQuery("query")
|
||||
if ok && response.Query != "" {
|
||||
response.Result, err = user.query(response.Query)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
}
|
||||
HTML(c, 200, "query.html", response)
|
||||
})
|
||||
|
||||
return r
|
||||
}
|
||||
|
||||
@@ -11,10 +11,5 @@
|
||||
<label>Tx Name: <input name="name" type="text"></label></br>
|
||||
<input type="submit">
|
||||
</form>
|
||||
<h2>Scripts</h2>
|
||||
<ul>
|
||||
{{ range $k, $v := .Scripts }}
|
||||
<li><a href="/exec?name={{ $k }}">{{ $k }}</a></li>
|
||||
{{ end }}
|
||||
</ul>
|
||||
{{ template "scripts" .Scripts }}
|
||||
{{ end }}
|
||||
|
||||
@@ -9,9 +9,10 @@
|
||||
<ul>
|
||||
{{ with .User }}
|
||||
{{ .Email }}
|
||||
<li><a href="dashboard">儀表板</a></li>
|
||||
<li><a href="edit">編輯</a></li>
|
||||
<li><a href="download">下載</a></li>
|
||||
<li><a href="exec">查詢</a></li>
|
||||
<li><a href="query">查詢</a></li>
|
||||
{{ end }}
|
||||
</nav>
|
||||
{{ block "main" .Data }}
|
||||
|
||||
8
templates/layouts/scripts.html
Normal file
8
templates/layouts/scripts.html
Normal file
@@ -0,0 +1,8 @@
|
||||
{{ define "scripts" }}
|
||||
<h3>常用指令</h3>
|
||||
<ul>
|
||||
{{ range $k, $v := . }}
|
||||
<li><a href="/query?query={{ urlquery $v }}">{{ $k }}</a></li>
|
||||
{{ end }}
|
||||
</ul>
|
||||
{{ end }}
|
||||
12
templates/query.html
Normal file
12
templates/query.html
Normal file
@@ -0,0 +1,12 @@
|
||||
{{ define "title" }}查詢{{ end }}
|
||||
{{ define "main" }}
|
||||
<h1>查詢</h1>
|
||||
{{ with .Result }}
|
||||
<pre><code>{{ . }}</code></pre>
|
||||
{{ end }}
|
||||
<form action="/query" method="GET">
|
||||
<input type="text" name="query" value="{{ .Query }}" autofocus>
|
||||
<input type="submit" value="查詢">
|
||||
</form>
|
||||
{{ template "scripts" .Scripts }}
|
||||
{{ end }}
|
||||
19
tx.go
19
tx.go
@@ -2,7 +2,6 @@ package main
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"fmt"
|
||||
"io"
|
||||
"os/exec"
|
||||
"strings"
|
||||
@@ -48,14 +47,14 @@ func (u *User) overwriteFile(tx string) (err error) {
|
||||
return err
|
||||
}
|
||||
|
||||
func (u *User) executeScript(w io.Writer, name string) (err error) {
|
||||
script, ok := SCRIPTS[name]
|
||||
if !ok {
|
||||
return fmt.Errorf("%s script not found", name)
|
||||
}
|
||||
cmd := exec.Command("ledger", append([]string{"--file", DEFAULT_JOURNAL}, script...)...)
|
||||
func (u *User) query(query string) (result string, err error) {
|
||||
var buf bytes.Buffer
|
||||
|
||||
cmd := exec.Command("ledger", "--file", DEFAULT_JOURNAL)
|
||||
cmd.Dir = u.Dir()
|
||||
cmd.Stdout = w
|
||||
cmd.Stderr = w
|
||||
return cmd.Run()
|
||||
cmd.Stdin = strings.NewReader(query)
|
||||
cmd.Stdout = &buf
|
||||
cmd.Stderr = &buf
|
||||
err = cmd.Run()
|
||||
return buf.String(), err
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user