forked from x/icebergs
opt some
This commit is contained in:
parent
dfebd2ddea
commit
cdc0ac35ff
@ -2,7 +2,6 @@ package cli
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
ice "github.com/shylinux/icebergs"
|
ice "github.com/shylinux/icebergs"
|
||||||
"github.com/shylinux/icebergs/base/aaa"
|
|
||||||
"github.com/shylinux/icebergs/base/mdb"
|
"github.com/shylinux/icebergs/base/mdb"
|
||||||
kit "github.com/shylinux/toolkits"
|
kit "github.com/shylinux/toolkits"
|
||||||
|
|
||||||
@ -27,10 +26,8 @@ func _daemon_show(m *ice.Message, cmd *exec.Cmd, out, err string) {
|
|||||||
|
|
||||||
h := m.Cmdx(mdb.INSERT, DAEMON, "", mdb.HASH,
|
h := m.Cmdx(mdb.INSERT, DAEMON, "", mdb.HASH,
|
||||||
kit.MDB_STATUS, Status.Start, kit.SSH_CMD, strings.Join(cmd.Args, " "),
|
kit.MDB_STATUS, Status.Start, kit.SSH_CMD, strings.Join(cmd.Args, " "),
|
||||||
kit.SSH_DIR, cmd.Dir, kit.SSH_ENV, cmd.Env, kit.SSH_PID, cmd.Process.Pid,
|
kit.SSH_DIR, cmd.Dir, kit.SSH_ENV, kit.Select("", cmd.Env), kit.SSH_PID, cmd.Process.Pid,
|
||||||
CMD_STDOUT, out, CMD_STDERR, err,
|
CMD_STDOUT, out, CMD_STDERR, err,
|
||||||
aaa.IP, m.Option(ice.MSG_USERIP), aaa.UA, m.Option(ice.MSG_USERUA),
|
|
||||||
aaa.USERNAME, m.Option(ice.MSG_USERNAME), aaa.USERROLE, m.Option(ice.MSG_USERROLE),
|
|
||||||
)
|
)
|
||||||
m.Echo("%d", cmd.Process.Pid)
|
m.Echo("%d", cmd.Process.Pid)
|
||||||
|
|
||||||
@ -55,6 +52,7 @@ var Status = struct{ Error, Start, Stop string }{
|
|||||||
}
|
}
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
RESTART = "restart"
|
||||||
START = "start"
|
START = "start"
|
||||||
STOP = "stop"
|
STOP = "stop"
|
||||||
)
|
)
|
||||||
@ -68,13 +66,21 @@ func init() {
|
|||||||
},
|
},
|
||||||
Commands: map[string]*ice.Command{
|
Commands: map[string]*ice.Command{
|
||||||
DAEMON: {Name: "daemon hash auto 添加 清理", Help: "守护进程", Action: map[string]*ice.Action{
|
DAEMON: {Name: "daemon hash auto 添加 清理", Help: "守护进程", Action: map[string]*ice.Action{
|
||||||
|
RESTART: {Name: "restart", Help: "重启", Hand: func(m *ice.Message, arg ...string) {
|
||||||
|
m.Cmd(DAEMON, STOP)
|
||||||
|
m.Cmd(DAEMON, START)
|
||||||
|
}},
|
||||||
START: {Name: "start cmd env dir", Help: "添加", Hand: func(m *ice.Message, arg ...string) {
|
START: {Name: "start cmd env dir", Help: "添加", Hand: func(m *ice.Message, arg ...string) {
|
||||||
m.Option(CMD_TYPE, DAEMON)
|
m.Option(CMD_TYPE, DAEMON)
|
||||||
|
m.Option(CMD_DIR, m.Option("dir"))
|
||||||
|
m.Option(CMD_ENV, kit.Split(m.Option("env"), " ="))
|
||||||
m.Cmdy(SYSTEM, kit.Split(m.Option("cmd")))
|
m.Cmdy(SYSTEM, kit.Split(m.Option("cmd")))
|
||||||
}},
|
}},
|
||||||
STOP: {Name: "stop", Help: "停止", Hand: func(m *ice.Message, arg ...string) {
|
STOP: {Name: "stop", Help: "停止", Hand: func(m *ice.Message, arg ...string) {
|
||||||
|
m.Option(mdb.FIELDS, "time,hash,status,pid,cmd,dir,env")
|
||||||
m.Cmd(mdb.SELECT, DAEMON, "", mdb.HASH, kit.MDB_HASH, m.Option(kit.MDB_HASH)).Table(func(index int, value map[string]string, head []string) {
|
m.Cmd(mdb.SELECT, DAEMON, "", mdb.HASH, kit.MDB_HASH, m.Option(kit.MDB_HASH)).Table(func(index int, value map[string]string, head []string) {
|
||||||
m.Cmd(mdb.MODIFY, DAEMON, "", mdb.HASH, kit.MDB_HASH, m.Option(kit.MDB_HASH), kit.MDB_STATUS, Status.Stop)
|
m.Cmd(mdb.MODIFY, DAEMON, "", mdb.HASH, kit.MDB_HASH, m.Option(kit.MDB_HASH), kit.MDB_STATUS, Status.Stop)
|
||||||
|
m.Debug("what %v", value)
|
||||||
m.Cmdy(SYSTEM, "kill", "-9", value[kit.SSH_PID])
|
m.Cmdy(SYSTEM, "kill", "-9", value[kit.SSH_PID])
|
||||||
})
|
})
|
||||||
}},
|
}},
|
||||||
@ -82,17 +88,18 @@ func init() {
|
|||||||
m.Cmdy(mdb.DELETE, DAEMON, "", mdb.HASH, kit.MDB_HASH, m.Option(kit.MDB_HASH))
|
m.Cmdy(mdb.DELETE, DAEMON, "", mdb.HASH, kit.MDB_HASH, m.Option(kit.MDB_HASH))
|
||||||
}},
|
}},
|
||||||
mdb.PRUNES: {Name: "prunes", Help: "清理", Hand: func(m *ice.Message, arg ...string) {
|
mdb.PRUNES: {Name: "prunes", Help: "清理", Hand: func(m *ice.Message, arg ...string) {
|
||||||
|
m.Option(mdb.FIELDS, "time,hash,status,pid,cmd,dir,env")
|
||||||
m.Cmdy(mdb.PRUNES, DAEMON, "", mdb.HASH, kit.MDB_STATUS, Status.Error)
|
m.Cmdy(mdb.PRUNES, DAEMON, "", mdb.HASH, kit.MDB_STATUS, Status.Error)
|
||||||
m.Cmdy(mdb.PRUNES, DAEMON, "", mdb.HASH, kit.MDB_STATUS, Status.Stop)
|
m.Cmdy(mdb.PRUNES, DAEMON, "", mdb.HASH, kit.MDB_STATUS, Status.Stop)
|
||||||
}},
|
}},
|
||||||
}, Hand: func(m *ice.Message, c *ice.Context, cmd string, arg ...string) {
|
}, Hand: func(m *ice.Message, c *ice.Context, cmd string, arg ...string) {
|
||||||
if len(arg) == 0 {
|
if len(arg) == 0 {
|
||||||
m.Option(mdb.FIELDS, "time,hash,status,pid,cmd,dir")
|
m.Option(mdb.FIELDS, "time,hash,status,pid,cmd,dir,env")
|
||||||
m.Cmdy(mdb.SELECT, DAEMON, "", mdb.HASH)
|
m.Cmdy(mdb.SELECT, DAEMON, "", mdb.HASH)
|
||||||
m.Table(func(index int, value map[string]string, head []string) {
|
m.Table(func(index int, value map[string]string, head []string) {
|
||||||
switch value[kit.MDB_STATUS] {
|
switch value[kit.MDB_STATUS] {
|
||||||
case Status.Start:
|
case Status.Start:
|
||||||
m.PushButton(STOP)
|
m.PushButton(RESTART, STOP)
|
||||||
default:
|
default:
|
||||||
m.PushButton(mdb.REMOVE)
|
m.PushButton(mdb.REMOVE)
|
||||||
}
|
}
|
||||||
|
@ -276,6 +276,10 @@ func _file_search(m *ice.Message, kind, name, text string, arg ...string) {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const (
|
||||||
|
OPEN = "open"
|
||||||
|
CLOSE = "close"
|
||||||
|
)
|
||||||
const (
|
const (
|
||||||
CAT_CB = "cat_cb"
|
CAT_CB = "cat_cb"
|
||||||
CAT = "cat"
|
CAT = "cat"
|
||||||
|
@ -79,7 +79,7 @@ const DREAM = "dream"
|
|||||||
func init() {
|
func init() {
|
||||||
Index.Merge(&ice.Context{
|
Index.Merge(&ice.Context{
|
||||||
Configs: map[string]*ice.Config{
|
Configs: map[string]*ice.Config{
|
||||||
DREAM: {Name: DREAM, Help: "梦想家", Value: kit.Data("path", "usr/local/work",
|
DREAM: {Name: DREAM, Help: "梦想家", Value: kit.Data(kit.MDB_PATH, "usr/local/work",
|
||||||
"cmd", []interface{}{"ice.bin", SPACE, "connect"},
|
"cmd", []interface{}{"ice.bin", SPACE, "connect"},
|
||||||
"env", kit.Dict("ctx_log", "bin/boot.log"),
|
"env", kit.Dict("ctx_log", "bin/boot.log"),
|
||||||
"miss", `#!/bin/bash
|
"miss", `#!/bin/bash
|
||||||
|
2
exec.go
2
exec.go
@ -16,7 +16,7 @@ func (m *Message) TryCatch(msg *Message, safe bool, hand ...func(msg *Message))
|
|||||||
case io.EOF:
|
case io.EOF:
|
||||||
case nil:
|
case nil:
|
||||||
default:
|
default:
|
||||||
fileline := kit.FileLine(4, 2)
|
fileline := kit.FileLine(4, 5)
|
||||||
m.Log(LOG_WARN, "catch: %s %s", e, fileline)
|
m.Log(LOG_WARN, "catch: %s %s", e, fileline)
|
||||||
m.Log("chain", msg.Format("chain"))
|
m.Log("chain", msg.Format("chain"))
|
||||||
m.Log(LOG_WARN, "catch: %s %s", e, fileline)
|
m.Log(LOG_WARN, "catch: %s %s", e, fileline)
|
||||||
|
@ -5,6 +5,7 @@ import (
|
|||||||
"github.com/shylinux/icebergs/base/cli"
|
"github.com/shylinux/icebergs/base/cli"
|
||||||
"github.com/shylinux/icebergs/base/gdb"
|
"github.com/shylinux/icebergs/base/gdb"
|
||||||
"github.com/shylinux/icebergs/base/mdb"
|
"github.com/shylinux/icebergs/base/mdb"
|
||||||
|
"github.com/shylinux/icebergs/base/nfs"
|
||||||
"github.com/shylinux/icebergs/base/web"
|
"github.com/shylinux/icebergs/base/web"
|
||||||
"github.com/shylinux/icebergs/core/code"
|
"github.com/shylinux/icebergs/core/code"
|
||||||
"github.com/shylinux/icebergs/core/wiki"
|
"github.com/shylinux/icebergs/core/wiki"
|
||||||
@ -158,18 +159,20 @@ var Index = &ice.Context{Name: TMUX, Help: "工作台",
|
|||||||
mdb.CREATE: {Name: "create name", Help: "添加", Hand: func(m *ice.Message, arg ...string) {
|
mdb.CREATE: {Name: "create name", Help: "添加", Hand: func(m *ice.Message, arg ...string) {
|
||||||
m.Option(cli.CMD_ENV, "TMUX", "")
|
m.Option(cli.CMD_ENV, "TMUX", "")
|
||||||
if m.Option(PANE) != "" {
|
if m.Option(PANE) != "" {
|
||||||
m.Cmd(cli.SYSTEM, TMUX, "split-window", "-t", m.Option(SESSION)+":"+m.Option(WINDOW)+"."+m.Option(PANE))
|
m.Cmdy(cli.SYSTEM, TMUX, "split-window", "-t", m.Option(SESSION)+":"+m.Option(WINDOW)+"."+m.Option(PANE))
|
||||||
|
|
||||||
} else if m.Option(WINDOW) != "" {
|
} else if m.Option(WINDOW) != "" {
|
||||||
m.Cmd(cli.SYSTEM, TMUX, "split-window", "-t", m.Option(SESSION)+":"+m.Option(WINDOW))
|
m.Cmdy(cli.SYSTEM, TMUX, "split-window", "-t", m.Option(SESSION)+":"+m.Option(WINDOW))
|
||||||
|
|
||||||
} else if m.Option(SESSION) != "" {
|
} else if m.Option(SESSION) != "" {
|
||||||
// 创建窗口
|
// 创建窗口
|
||||||
m.Cmd(cli.SYSTEM, TMUX, "new-window", "-t", m.Option(SESSION), "-dn", m.Option("name"))
|
m.Cmdy(cli.SYSTEM, TMUX, "new-window", "-t", m.Option(SESSION), "-dn", m.Option(kit.MDB_NAME))
|
||||||
} else {
|
} else {
|
||||||
// 创建会话
|
// 创建会话
|
||||||
m.Cmd(cli.SYSTEM, TMUX, "new-session", "-ds", m.Option("name"))
|
m.Option(cli.CMD_DIR, path.Join(m.Conf(web.DREAM, kit.META_PATH), m.Option(kit.MDB_NAME)))
|
||||||
|
m.Cmdy(cli.SYSTEM, TMUX, "new-session", "-ds", m.Option(kit.MDB_NAME))
|
||||||
}
|
}
|
||||||
|
m.Option(ice.MSG_PROCESS, "_refresh")
|
||||||
}},
|
}},
|
||||||
mdb.MODIFY: {Name: "modify", Help: "编辑", Hand: func(m *ice.Message, arg ...string) {
|
mdb.MODIFY: {Name: "modify", Help: "编辑", Hand: func(m *ice.Message, arg ...string) {
|
||||||
switch arg[0] {
|
switch arg[0] {
|
||||||
@ -201,8 +204,14 @@ var Index = &ice.Context{Name: TMUX, Help: "工作台",
|
|||||||
}},
|
}},
|
||||||
|
|
||||||
mdb.INPUTS: {Name: "inputs", Help: "补全", Hand: func(m *ice.Message, arg ...string) {
|
mdb.INPUTS: {Name: "inputs", Help: "补全", Hand: func(m *ice.Message, arg ...string) {
|
||||||
|
switch arg[0] {
|
||||||
|
case kit.MDB_NAME:
|
||||||
|
m.Option(nfs.DIR_ROOT, m.Conf(web.DREAM, kit.META_PATH))
|
||||||
|
m.Cmdy(nfs.DIR, "./", "name size time")
|
||||||
|
default:
|
||||||
m.Option(mdb.FIELDS, "name,type,text")
|
m.Option(mdb.FIELDS, "name,type,text")
|
||||||
m.Cmdy(mdb.SELECT, SCRIPT, "", mdb.HASH)
|
m.Cmdy(mdb.SELECT, SCRIPT, "", mdb.HASH)
|
||||||
|
}
|
||||||
}},
|
}},
|
||||||
|
|
||||||
SCRIPT: {Name: "script name", Help: "脚本", Hand: func(m *ice.Message, arg ...string) {
|
SCRIPT: {Name: "script name", Help: "脚本", Hand: func(m *ice.Message, arg ...string) {
|
||||||
|
9
type.go
9
type.go
@ -103,7 +103,11 @@ func (c *Context) _hand(m *Message, cmd *Command, key string, k string, h *Actio
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if h.Hand == nil {
|
||||||
|
m.Cmdy(kit.Split(h.Name))
|
||||||
|
} else {
|
||||||
h.Hand(m, arg...)
|
h.Hand(m, arg...)
|
||||||
|
}
|
||||||
return m
|
return m
|
||||||
}
|
}
|
||||||
func (c *Context) cmd(m *Message, cmd *Command, key string, arg ...string) *Message {
|
func (c *Context) cmd(m *Message, cmd *Command, key string, arg ...string) *Message {
|
||||||
@ -165,13 +169,16 @@ func (c *Context) Merge(s *Context, x Server) *Context {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for k, a := range v.Action {
|
for k, a := range v.Action {
|
||||||
|
kit.Value(v.Meta, kit.Keys("trans", k), a.Help)
|
||||||
|
if a.Hand == nil {
|
||||||
|
continue
|
||||||
|
}
|
||||||
if a.List == nil {
|
if a.List == nil {
|
||||||
a.List = c._split(a.Name)
|
a.List = c._split(a.Name)
|
||||||
}
|
}
|
||||||
if len(a.List) > 0 {
|
if len(a.List) > 0 {
|
||||||
v.Meta[k] = a.List
|
v.Meta[k] = a.List
|
||||||
}
|
}
|
||||||
kit.Value(v.Meta, kit.Keys("trans", k), a.Help)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user