1
0
mirror of https://shylinux.com/x/ContextOS synced 2025-04-28 18:02:02 +08:00

add LocalCGI

This commit is contained in:
shaoying 2019-11-15 21:26:25 +08:00
parent dd3f62b90a
commit 88bb4eaf27
7 changed files with 171 additions and 34 deletions

View File

@ -1,11 +1,13 @@
package ctx package ctx
import ( import (
"html/template" "text/template"
"bytes"
"io" "io"
"path" "path"
"strings" "strings"
"toolkit"
) )
func index(name string, arg ...interface{}) interface{} { func index(name string, arg ...interface{}) interface{} {
@ -75,6 +77,18 @@ func index(name string, arg ...interface{}) interface{} {
} }
var CGI = template.FuncMap{ var CGI = template.FuncMap{
"options": func(arg ...interface{}) string {
switch value := index("option", arg...).(type) {
case string:
return value
case []string:
return strings.Join(value, "")
}
return ""
},
"option": func(arg ...interface{}) interface{} {
return index("option", arg...)
},
"conf": func(arg ...interface{}) interface{} { "conf": func(arg ...interface{}) interface{} {
switch m := arg[0].(type) { switch m := arg[0].(type) {
case *Message: case *Message:
@ -90,20 +104,114 @@ var CGI = template.FuncMap{
} }
return nil return nil
}, },
"option": func(arg ...interface{}) interface{} { "cmd": func(arg ...interface{}) interface{} {
return index("option", arg...) switch m := arg[0].(type) {
}, case *Message:
"options": func(arg ...interface{}) string { switch c := arg[1].(type) {
switch value := index("option", arg...).(type) { case string:
case string: return m.Cmd(c, arg[2:])
return value }
case []string:
return strings.Join(value, "")
} }
return "" return nil
},
"append": func(arg ...interface{}) interface{} {
switch m := arg[0].(type) {
case *Message:
if len(arg) == 1 {
return m.Meta["append"]
}
if len(arg) > 1 {
switch c := arg[1].(type) {
case string:
if len(arg) > 2 {
switch i := arg[2].(type) {
case int:
return kit.Select("", m.Meta[c], i)
}
}
return m.Meta[c]
}
}
}
return nil
},
"result": func(arg ...interface{}) interface{} {
switch m := arg[0].(type) {
case *Message:
return m.Meta["result"]
}
return nil
},
"results": func(arg ...interface{}) interface{} {
switch m := arg[0].(type) {
case *Message:
return strings.Join(m.Meta["result"], "")
}
return nil
}, },
} }
func LocalCGI(m *Message, c *Context) *template.FuncMap {
cgi := template.FuncMap{
"table": func(arg ...interface{}) interface{} {
if len(arg) == 0 {
return ""
}
switch msg := arg[0].(type) {
case *Message:
res := []map[string]string{}
msg.Table(func(index int, value map[string]string) {
res = append(res, value)
})
return res
case string:
sub := m.Spawn()
head := []string{}
for i, l := range strings.Split(strings.TrimSpace(msg), "\n") {
if i == 0 {
head = kit.Split(l, ' ', 100)
continue
}
for j, v := range strings.Split(l, " ") {
sub.Push(head[j], v)
}
}
return sub
}
return nil
},
"format": func(arg ...interface{}) interface{} {
switch msg := arg[0].(type) {
case *Message:
buffer := bytes.NewBuffer([]byte{})
tmpl := m.Optionv("tmpl").(*template.Template)
m.Assert(tmpl.ExecuteTemplate(buffer, kit.Select("table", arg, 1), msg))
return string(buffer.Bytes())
}
return nil
},
}
for k, v := range c.Commands {
if strings.HasPrefix(k, "/") || strings.HasPrefix(k, "_") {
continue
}
func(k string, v *Command) {
cgi[k] = func(arg ...interface{}) interface{} {
msg := m.Spawn()
v.Hand(msg, c, k, kit.Trans(arg)...)
buffer := bytes.NewBuffer([]byte{})
tmpl := m.Optionv("tmpl").(*template.Template)
m.Assert(tmpl.ExecuteTemplate(buffer, kit.Select("code", "table", len(msg.Meta["append"]) > 0), msg))
return string(buffer.Bytes())
}
}(k, v)
}
for k, v := range CGI {
cgi[k] = v
}
return &cgi
}
func ExecuteFile(m *Message, w io.Writer, p string) error { func ExecuteFile(m *Message, w io.Writer, p string) error {
tmpl := template.New("render").Funcs(CGI) tmpl := template.New("render").Funcs(CGI)
tmpl.ParseGlob(p) tmpl.ParseGlob(p)

View File

@ -450,7 +450,7 @@ var Index = &ctx.Context{Name: "ssh", Help: "集群中心",
}) })
default: // 记录值 default: // 记录值
index := kit.Int(arg[2]) - 1 index := kit.Int(arg[2]) - 1 - m.Confi("flow", []string{m.Option("river"), "data", arg[1], "meta", "offset"})
switch m.Option("format") { switch m.Option("format") {
case "object": case "object":
m.Confm("flow", []string{m.Option("river"), "data", arg[1], "list", kit.Format(index)}, func(key string, value string) { m.Confm("flow", []string{m.Option("river"), "data", arg[1], "list", kit.Format(index)}, func(key string, value string) {

View File

@ -11,7 +11,6 @@ import (
"bytes" "bytes"
"encoding/json" "encoding/json"
"fmt" "fmt"
"html/template"
"io" "io"
"io/ioutil" "io/ioutil"
"mime/multipart" "mime/multipart"
@ -22,6 +21,7 @@ import (
"path/filepath" "path/filepath"
"strconv" "strconv"
"strings" "strings"
"text/template"
) )
type MUX interface { type MUX interface {

View File

@ -232,7 +232,11 @@ var Index = &ctx.Context{Name: "code", Help: "代码中心",
m.Cmdy("ssh._route", m.Option("dream"), "ssh.data", "update", m.Option("table"), arg[1], arg[3], arg[4]) m.Cmdy("ssh._route", m.Option("dream"), "ssh.data", "update", m.Option("table"), arg[1], arg[3], arg[4])
arg = []string{"list", m.Option("dream"), m.Option("table")} arg = []string{"list", m.Option("dream"), m.Option("table")}
} }
m.Cmdy("ssh._route", arg[1], "ssh.data", "show", arg[2:]) if len(arg) > 1 {
m.Cmdy("ssh._route", arg[1], "ssh.data", "show", arg[2:])
break
}
m.Cmdy("ssh.data", "show")
} }
return return
}}, }},

View File

@ -9,8 +9,9 @@ import (
"bytes" "bytes"
"encoding/json" "encoding/json"
"html/template"
"path" "path"
"strings"
"text/template"
) )
var Index = &ctx.Context{Name: "wiki", Help: "文档中心", var Index = &ctx.Context{Name: "wiki", Help: "文档中心",
@ -47,9 +48,9 @@ var Index = &ctx.Context{Name: "wiki", Help: "文档中心",
}, },
}, Help: "组件列表"}, }, Help: "组件列表"},
"level": {Name: "level", Value: "local/wiki/自然/编程", Help: "路由数量"}, "level": {Name: "level", Value: "usr/local/wiki", Help: "文档路径"},
"class": {Name: "class", Value: "", Help: "路由数量"}, "class": {Name: "class", Value: "", Help: "文档目录"},
"favor": {Name: "favor", Value: "index.md", Help: "路由数量"}, "favor": {Name: "favor", Value: "index.md", Help: "默认文档"},
}, },
Commands: map[string]*ctx.Command{ Commands: map[string]*ctx.Command{
"tree": {Name: "tree", Help: "目录", Form: map[string]int{"level": 1, "class": 1}, Hand: func(m *ctx.Message, c *ctx.Context, key string, arg ...string) (e error) { "tree": {Name: "tree", Help: "目录", Form: map[string]int{"level": 1, "class": 1}, Hand: func(m *ctx.Message, c *ctx.Context, key string, arg ...string) (e error) {
@ -61,10 +62,37 @@ var Index = &ctx.Context{Name: "wiki", Help: "文档中心",
which := m.Cmdx("nfs.path", path.Join(m.Confx("level"), m.Confx("class", arg, 1), m.Confx("favor", arg, 0))) which := m.Cmdx("nfs.path", path.Join(m.Confx("level"), m.Confx("class", arg, 1), m.Confx("favor", arg, 0)))
buffer := bytes.NewBuffer([]byte{}) buffer := bytes.NewBuffer([]byte{})
template.Must(template.ParseFiles(which)).Funcs(ctx.CGI).Execute(buffer, m) tmpl := template.New("render").Funcs(*ctx.LocalCGI(m, c))
tmpl = template.Must(tmpl.ParseGlob(path.Join(m.Conf("route", "template_dir"), "/*.tmpl")))
tmpl = template.Must(tmpl.ParseGlob(path.Join(m.Conf("route", "template_dir"), m.Cap("route"), "/*.tmpl")))
tmpl = template.Must(tmpl.ParseFiles(which))
m.Optionv("tmpl", tmpl)
m.Assert(tmpl.ExecuteTemplate(buffer, path.Base(which), m))
m.Echo(string(markdown.ToHTML(buffer.Bytes(), nil, nil))) m.Echo(string(markdown.ToHTML(buffer.Bytes(), nil, nil)))
return return
}}, }},
"note": {Name: "note file", Help: "便签", Hand: func(m *ctx.Message, c *ctx.Context, key string, arg ...string) (e error) {
if len(arg) > 0 {
m.Cmd(kit.Select("tree", "text", strings.HasSuffix(arg[0], ".md")), arg[0])
} else {
m.Cmd("tree")
}
return
}},
"runs": {Name: "run", Help: "便签", Hand: func(m *ctx.Message, c *ctx.Context, key string, arg ...string) (e error) {
m.Cmdy(arg).Set("append")
return
}},
"run": {Name: "run", Help: "便签", Hand: func(m *ctx.Message, c *ctx.Context, key string, arg ...string) (e error) {
m.Cmdy(arg)
return
}},
"time": {Name: "time", Help: "便签", Hand: func(m *ctx.Message, c *ctx.Context, key string, arg ...string) (e error) {
m.Cmdy("cli.time", "show").Set("append")
return
}},
"svg": {Name: "svg", Help: "绘图", Hand: func(m *ctx.Message, c *ctx.Context, key string, arg ...string) (e error) { "svg": {Name: "svg", Help: "绘图", Hand: func(m *ctx.Message, c *ctx.Context, key string, arg ...string) (e error) {
m.Echo(arg[0]) m.Echo(arg[0])
@ -119,21 +147,6 @@ var Index = &ctx.Context{Name: "wiki", Help: "文档中心",
} }
return return
}}, }},
"tip": {Name: "tip action table index ...", Help: "便签", Hand: func(m *ctx.Message, c *ctx.Context, key string, arg ...string) (e error) {
switch arg[0] {
case "show":
if len(arg) == 1 || arg[2] == "" {
m.Cmdy("ssh.data", "show", arg[1])
} else {
m.Cmdy("ssh.data", "show", arg[1], arg[2])
}
case "insert":
m.Cmdy("ssh.data", "insert", arg[1], arg[3:])
case "update":
m.Cmdy("ssh.data", "update", arg[1], arg[2], arg[3:])
}
return
}},
}, },
} }

View File

@ -1,3 +1,11 @@
kit note "记事本" public "ssh._route" _ "web.wiki.note" \
text "" name you imports plugin_you action auto \
text "" name doc imports plugin_doc view long action auto \
button "查看" action auto \
button "返回" cb Last \
exports doc file \
feature display inner
kit tips "便签" private "web.code.favor" list \ kit tips "便签" private "web.code.favor" list \
text "" name dream imports plugin_you action auto \ text "" name dream imports plugin_you action auto \
text "tip" name table imports plugin_vim_table action auto \ text "tip" name table imports plugin_vim_table action auto \

View File

@ -1493,6 +1493,10 @@ function Output(plugin, type, msg, cb, target, option) {
kit.Selector(option, ".args", function(item) { kit.Selector(option, ".args", function(item) {
msg.Option(item.name, item.value) msg.Option(item.name, item.value)
}) })
if (name == "value") {
name = line.key
id = option.index.value
}
plugin.Run(event, [id, meta[item], name, event.target.value], function(msg) { plugin.Run(event, [id, meta[item], name, event.target.value], function(msg) {
td.innerHTML = event.target.value td.innerHTML = event.target.value
plugin.ontoast("修改成功") plugin.ontoast("修改成功")