mirror of
https://github.com/aclindsa/moneygo.git
synced 2024-10-30 07:40:05 -04:00
lua: Fetch reports from directory
This commit is contained in:
parent
5478ba3fd0
commit
af704250e2
29
reports.go
29
reports.go
@ -5,6 +5,7 @@ import (
|
||||
"github.com/yuin/gopher-lua"
|
||||
"log"
|
||||
"net/http"
|
||||
"path"
|
||||
"time"
|
||||
)
|
||||
|
||||
@ -28,6 +29,15 @@ func ReportHandler(w http.ResponseWriter, r *http.Request) {
|
||||
}
|
||||
|
||||
if r.Method == "GET" {
|
||||
var reportname string
|
||||
n, err := GetURLPieces(r.URL.Path, "/report/%s", &reportname)
|
||||
if err != nil || n != 1 {
|
||||
WriteError(w, 3 /*Invalid Request*/)
|
||||
return
|
||||
}
|
||||
|
||||
reportpath := path.Join(baseDir, "reports", reportname+".lua")
|
||||
|
||||
// Create a new LState without opening the default libs for security
|
||||
L := lua.NewState(lua.Options{SkipOpenLibs: true})
|
||||
defer L.Close()
|
||||
@ -53,7 +63,9 @@ func ReportHandler(w http.ResponseWriter, r *http.Request) {
|
||||
NRet: 0,
|
||||
Protect: true,
|
||||
}, lua.LString(pair.n)); err != nil {
|
||||
panic(err)
|
||||
WriteError(w, 999 /*Internal Error*/)
|
||||
log.Print(err)
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
@ -62,21 +74,12 @@ func ReportHandler(w http.ResponseWriter, r *http.Request) {
|
||||
luaRegisterBalances(L)
|
||||
luaRegisterDates(L)
|
||||
|
||||
err := L.DoString(`accounts = account.get_all()
|
||||
last_parent = nil
|
||||
for id, account in pairs(accounts) do
|
||||
parent = account.parent
|
||||
print(account, parent, account.security)
|
||||
if parent then
|
||||
print(last_parent, parent)
|
||||
print("parent equals last:", last_parent == parent)
|
||||
last_parent = parent
|
||||
end
|
||||
end
|
||||
`)
|
||||
err = L.DoFile(reportpath)
|
||||
|
||||
if err != nil {
|
||||
WriteError(w, 3 /*Invalid Request*/)
|
||||
log.Print("lua:" + err.Error())
|
||||
return
|
||||
}
|
||||
}
|
||||
}
|
||||
|
8
reports/test.lua
Normal file
8
reports/test.lua
Normal file
@ -0,0 +1,8 @@
|
||||
accounts = get_accounts()
|
||||
|
||||
for id, account in pairs(accounts) do
|
||||
print(account, account.security)
|
||||
a = account:balance(date.new("2015-12-01"), date.new("2017-12-01"))
|
||||
b = account:balance(date.new("2015-06-01"), date.new("2015-12-01"))
|
||||
print(a, b, a+b, account:balance())
|
||||
end
|
Loading…
Reference in New Issue
Block a user