1
0
forked from x/icebergs
This commit is contained in:
shylinux 2020-01-15 03:06:28 +08:00
parent e519e934a3
commit d044f2266e
4 changed files with 75 additions and 61 deletions

View File

@ -557,6 +557,11 @@ var Index = &ice.Context{Name: "web", Help: "网络模块",
for k, v := range head { for k, v := range head {
req.Header.Set(k, v) req.Header.Set(k, v)
} }
if list, ok := m.Optionv("header").([]string); ok {
for i := 0; i < len(list)-1; i += 2 {
req.Header.Set(list[i], list[i+1])
}
}
kit.Fetch(client["header"], func(key string, value string) { kit.Fetch(client["header"], func(key string, value string) {
req.Header.Set(key, value) req.Header.Set(key, value)
}) })
@ -617,9 +622,16 @@ var Index = &ice.Context{Name: "web", Help: "网络模块",
m.Optionv("response", res) m.Optionv("response", res)
m.Echo(m.Cmd(ice.WEB_CACHE, "download", res.Header.Get("Content-Type"), uri).Append("data")) m.Echo(m.Cmd(ice.WEB_CACHE, "download", res.Header.Get("Content-Type"), uri).Append("data"))
default: default:
if strings.HasPrefix(res.Header.Get("Content-Type"), "text/html") {
b, _ := ioutil.ReadAll(res.Body)
m.Echo(string(b))
break
}
// 解析结果 // 解析结果
var data interface{} var data interface{}
m.Assert(json.NewDecoder(res.Body).Decode(&data)) m.Assert(json.NewDecoder(res.Body).Decode(&data))
data = kit.KeyValue(map[string]interface{}{}, "", data)
m.Info("res: %s", kit.Formats(data)) m.Info("res: %s", kit.Formats(data))
kit.Fetch(data, func(key string, value interface{}) { kit.Fetch(data, func(key string, value interface{}) {
switch value := value.(type) { switch value := value.(type) {
@ -629,7 +641,6 @@ var Index = &ice.Context{Name: "web", Help: "网络模块",
m.Push(key, kit.Format(value)) m.Push(key, kit.Format(value))
} }
}) })
m.Info("res: %s", m.Formats("meta"))
} }
}) })
} }

View File

@ -1,4 +1,4 @@
package lk package lark
import ( import (
"github.com/shylinux/icebergs" "github.com/shylinux/icebergs"
@ -7,30 +7,21 @@ import (
"github.com/shylinux/toolkits" "github.com/shylinux/toolkits"
"encoding/json" "encoding/json"
"net/http"
"strings" "strings"
"time" "time"
) )
func get(m *ice.Message, arg ...string) *ice.Message { func post(m *ice.Message, bot string, arg ...interface{}) {
m.Option("temp_expire", -1) m.Richs("app", nil, bot, func(key string, value map[string]interface{}) {
m.Option("format", "object") m.Option("header", "Authorization", "Bearer "+m.Cmdx("app", "token", bot), "Content-Type", "application/json")
m.Cmdy("web.get", "feishu", arg, "temp", "data") m.Cmdy(ice.WEB_SPIDE, "lark", arg)
return m })
}
func post(m *ice.Message, arg ...string) *ice.Message {
m.Option("temp_expire", -1)
m.Option("format", "object")
m.Cmdy("web.get", "method", "POST", "feishu", arg,
"content_type", "application/json",
"temp", "data",
)
return m
} }
func parse(m *ice.Message) { func parse(m *ice.Message) {
data := m.Optionv("content_data") data := m.Optionv("content_data")
if data == nil { if data == nil {
json.NewDecoder(m.Optionv("request").(*http.Request).Body).Decode(&data) json.NewDecoder(m.R.Body).Decode(&data)
m.Optionv("content_data", data) m.Optionv("content_data", data)
switch d := data.(type) { switch d := data.(type) {
@ -54,43 +45,58 @@ func parse(m *ice.Message) {
}) != nil { }) != nil {
m.Option("msg.type", "event_click") m.Option("msg.type", "event_click")
} }
m.Log("info", "msg: %v", kit.Formats(data)) m.Info("msg: %v", kit.Formats(data))
} }
var Index = &ice.Context{Name: "lk", Help: "lark", var Index = &ice.Context{Name: "lark", Help: "lark",
Caches: map[string]*ice.Cache{}, Caches: map[string]*ice.Cache{},
Configs: map[string]*ice.Config{ Configs: map[string]*ice.Config{
"app": &ice.Config{Name: "app", Value: map[string]interface{}{}, Help: "服务配置"}, "app": &ice.Config{Name: "app", Help: "服务配置", Value: kit.Data(kit.MDB_SHORT, "name", "lark", "https://open.feishu.cn")},
"user": &ice.Config{Name: "user", Value: map[string]interface{}{}, Help: "服务配置"}, "user": &ice.Config{Name: "user", Help: "用户配置", Value: kit.Data()},
}, },
Commands: map[string]*ice.Command{ Commands: map[string]*ice.Command{
ice.ICE_INIT: {Hand: func(m *ice.Message, c *ice.Context, cmd string, arg ...string) {
m.Cmd(ice.CTX_CONFIG, "load", "lark.json")
m.Confm("app", "meta.userrole", func(key string, value string) {
m.Cmd(ice.AAA_ROLE, value, key)
})
m.Cmd(ice.WEB_SPIDE, "add", "lark", m.Conf("app", "meta.lark"))
}},
ice.ICE_EXIT: {Hand: func(m *ice.Message, c *ice.Context, cmd string, arg ...string) {
m.Cmd(ice.CTX_CONFIG, "save", "lark.json", "web.chat.lark.app")
}},
"app": {Name: "app login|token bot", Help: "应用", Hand: func(m *ice.Message, c *ice.Context, key string, arg ...string) { "app": {Name: "app login|token bot", Help: "应用", Hand: func(m *ice.Message, c *ice.Context, key string, arg ...string) {
if len(arg) == 0 { if len(arg) == 0 {
m.Confm("app", func(key string, value map[string]interface{}) { m.Richs("app", nil, "*", func(key string, value map[string]interface{}) {
m.Push("key", key) m.Push("key", value)
m.Push("id", value["id"])
}) })
m.Table()
return return
} }
switch arg[0] { switch arg[0] {
case "login": case "login":
m.Confv("app", arg[1], map[string]interface{}{"id": arg[2], "mm": arg[3]}) m.Rich("app", nil, kit.Dict("name", arg[1], "id", arg[2], "mm", arg[3]))
case "token": case "token":
if now := time.Now().Unix(); !m.Confs("app", []string{arg[1], "token"}) || int64(m.Confi("app", []string{arg[1], "expire"})) < now { m.Richs("app", nil, arg[1], func(key string, value map[string]interface{}) {
post(m, "auth/v3/tenant_access_token/internal/", "app_id", m.Conf("app", []string{arg[1], "id"}), if now := time.Now().Unix(); kit.Format(value["token"]) == "" || kit.Int64(value["expire"]) < now {
"app_secret", m.Conf("app", []string{arg[1], "mm"})) m.Cmdy(ice.WEB_SPIDE, "lark", "/open-apis/auth/v3/tenant_access_token/internal/", "app_id", value["id"], "app_secret", value["mm"])
m.Conf("app", []string{arg[1], "token"}, m.Append("tenant_access_token")) value["token"] = m.Append("tenant_access_token")
m.Conf("app", []string{arg[1], "expire"}, kit.Int64(m.Append("expire"))+now) value["expire"] = kit.Int64(m.Append("expire")) + now
m.Set("result") m.Set("result")
}
m.Echo("%s", value["token"])
})
case "watch":
for _, v := range arg[3:] {
m.Watch(v, "web.chat.lark.send", arg[1], arg[2], v)
} }
m.Echo(m.Conf("app", []string{arg[1], "token"}))
} }
return return
}}, }},
"ship": {Name: "ship", Help: "组织", Hand: func(m *ice.Message, c *ice.Context, key string, arg ...string) { "ship": {Name: "ship", Help: "组织", Hand: func(m *ice.Message, c *ice.Context, key string, arg ...string) {
data := kit.UnMarshal(m.Cmdx("web.get", "feishu", "contact/v1/scope/get/", data := kit.UnMarshal(m.Cmdx(ice.WEB_SPIDE, "lark", "/open-apis/contact/v1/scope/get/",
"headers", "Authorization", "Bearer "+m.Cmdx(".app", "token", "bot"), "headers", "Authorization", "Bearer "+m.Cmdx(".app", "token", "bot"),
)) ))
kit.Fetch(kit.Value(data, "data.authed_departments"), func(index int, value string) { kit.Fetch(kit.Value(data, "data.authed_departments"), func(index int, value string) {
@ -124,11 +130,15 @@ var Index = &ice.Context{Name: "lk", Help: "lark",
"user": {Name: "user code|email|mobile", Help: "用户", Hand: func(m *ice.Message, c *ice.Context, key string, arg ...string) { "user": {Name: "user code|email|mobile", Help: "用户", Hand: func(m *ice.Message, c *ice.Context, key string, arg ...string) {
switch arg[0] { switch arg[0] {
case "code": case "code":
post(m, "/connect/qrconnect/oauth2/access_token/", m.Richs("app", nil, "bot", func(key string, value map[string]interface{}) {
"app_secret", m.Conf("app", []string{"bot", "mm"}), "app_id", m.Conf("app", []string{"bot", "id"}), m.Cmd(ice.WEB_SPIDE, "lark", "/connect/qrconnect/oauth2/access_token/",
"grant_type", "authorization_code", "code", arg[1], "app_secret", value["mm"], "app_id", value["id"],
) "grant_type", "authorization_code", "code", arg[1],
msg := get(m.Spawn(), "/connect/qrconnect/oauth2/user_info/", )
})
msg := m.Cmd(ice.WEB_SPIDE, "lark", "/connect/qrconnect/oauth2/user_info/",
"headers", "Authorization", "Bearer "+m.Append("access_token"), "headers", "Authorization", "Bearer "+m.Append("access_token"),
) )
m.Confv("user", m.Append("open_id"), map[string]interface{}{ m.Confv("user", m.Append("open_id"), map[string]interface{}{
@ -155,13 +165,7 @@ var Index = &ice.Context{Name: "lk", Help: "lark",
ps = append(ps, kit.Select("mobile", "email", strings.Contains(arg[i], "@"))+"_users") ps = append(ps, kit.Select("mobile", "email", strings.Contains(arg[i], "@"))+"_users")
} }
data := kit.UnMarshal(m.Cmdx("web.get", "feishu", "user/v1/batch_get_id", us, post(m, "bot", "GET", "/open-apis/user/v1/batch_get_id", us)
"headers", "Authorization", "Bearer "+m.Cmdx(".app", "token", "bot")))
for i, v := range ps {
m.Append(arg[i], kit.Value(data, []string{"data", v, arg[i], "0", "open_id"}))
}
m.Table()
} }
return return
}}, }},
@ -248,7 +252,7 @@ var Index = &ice.Context{Name: "lk", Help: "lark",
continue continue
} }
line = append(line, map[string]interface{}{ line = append(line, map[string]interface{}{
"tag": "text", "text": v, "tag": "text", "text": v + " ",
}) })
} }
content = append(content, line) content = append(content, line)
@ -261,14 +265,9 @@ var Index = &ice.Context{Name: "lk", Help: "lark",
}, },
}) })
} }
} }
m.Cmdy("web.get", "method", "POST", "feishu", "message/v4/send/", post(m, "bot", "/open-apis/message/v4/send/", "data", kit.Formats(form))
"headers", "Authorization", "Bearer "+m.Cmdx(".app", "token", "bot"),
"content_data", kit.Formats(form), "content_type", "application/json",
"temp", "data", "data.message_id",
)
return return
}}, }},
"/msg": {Name: "/msg", Help: "消息", Hand: func(m *ice.Message, c *ice.Context, key string, arg ...string) { "/msg": {Name: "/msg", Help: "消息", Hand: func(m *ice.Message, c *ice.Context, key string, arg ...string) {
@ -276,7 +275,8 @@ var Index = &ice.Context{Name: "lk", Help: "lark",
switch m.Option("msg.type") { switch m.Option("msg.type") {
case "url_verification": case "url_verification":
m.Echo(kit.Format(map[string]interface{}{"challenge": m.Option("challenge")})) m.Push("_output", "result")
m.Echo(kit.Format(map[string]interface{}{"challenge": m.Option("msg.challenge")}))
case "event_callback": case "event_callback":
switch m.Option("type") { switch m.Option("type") {
@ -291,11 +291,14 @@ var Index = &ice.Context{Name: "lk", Help: "lark",
} }
default: default:
if m.Options("open_chat_id") { if m.Options("open_chat_id") {
m.Option("username", m.Option("open_id")) m.Option(ice.MSG_USERNAME, m.Option("open_id"))
m.Option("sessid", m.Cmdx("aaa.user", "session", "select")) m.Option(ice.MSG_USERROLE, m.Cmdx(ice.AAA_ROLE, "check", m.Option(ice.MSG_USERNAME)))
m.Cmd("ssh._check", "work", "create", m.Option("username")) if cmd := kit.Split(m.Option("text_without_at_bot")); m.Right(cmd) {
msg := m.Cmd(kit.Split(m.Option("text_without_at_bot"))) m.Cmdy(cmd)
m.Cmdy(".send", m.Option("open_chat_id"), kit.Select("你好", msg.Result())) } else {
m.Echo("no right")
}
m.Cmdy("send", m.Option("open_chat_id"), kit.Select("你好", m.Result()))
} }
} }
case "event_click": case "event_click":

View File

@ -6,7 +6,7 @@ import (
_ "github.com/shylinux/icebergs/core" _ "github.com/shylinux/icebergs/core"
_ "github.com/shylinux/icebergs/misc" _ "github.com/shylinux/icebergs/misc"
_ "github.com/shylinux/icebergs/misc/lk" _ "github.com/shylinux/icebergs/misc/lark"
_ "github.com/shylinux/icebergs/misc/mp" _ "github.com/shylinux/icebergs/misc/mp"
_ "github.com/shylinux/icebergs/misc/pi" _ "github.com/shylinux/icebergs/misc/pi"
_ "github.com/shylinux/icebergs/misc/wx" _ "github.com/shylinux/icebergs/misc/wx"