From 67b070fefde5984371e832ad9ebe8d976709ada1 Mon Sep 17 00:00:00 2001 From: Suika99 <290760339@qq.com> Date: Fri, 2 Jul 2021 00:56:31 +0800 Subject: [PATCH 01/79] test --- .idea/workspace.xml | 25 +++++++++++++++++++++++-- 1 file changed, 23 insertions(+), 2 deletions(-) diff --git a/.idea/workspace.xml b/.idea/workspace.xml index fd386a1b..856561d4 100644 --- a/.idea/workspace.xml +++ b/.idea/workspace.xml @@ -1,13 +1,17 @@ - + + + + + - + @@ -27,6 +31,12 @@ + + + + + + @@ -61,4 +71,15 @@ true + + + + + file://$PROJECT_DIR$/plugin_bilibili/live_info.go + 38 + + + + \ No newline at end of file From 6fb46706b5963abbb6ccf603b93d714715166ad7 Mon Sep 17 00:00:00 2001 From: Suika99 <290760339@qq.com> Date: Fri, 2 Jul 2021 00:58:08 +0800 Subject: [PATCH 02/79] push test --- .idea/workspace.xml | 6 ------ 1 file changed, 6 deletions(-) diff --git a/.idea/workspace.xml b/.idea/workspace.xml index 856561d4..692e4055 100644 --- a/.idea/workspace.xml +++ b/.idea/workspace.xml @@ -31,12 +31,6 @@ - - - - - - From 80a839d60a9e4bf6fe9a063b9ec2244c946dfb88 Mon Sep 17 00:00:00 2001 From: Suika99 <290760339@qq.com> Date: Fri, 2 Jul 2021 00:59:12 +0800 Subject: [PATCH 03/79] Revert "test" This reverts commit a1b1bbf77cbe3d76e9409b2eef9cf36fcf8f4880. --- .idea/workspace.xml | 19 ++----------------- 1 file changed, 2 insertions(+), 17 deletions(-) diff --git a/.idea/workspace.xml b/.idea/workspace.xml index 692e4055..fd386a1b 100644 --- a/.idea/workspace.xml +++ b/.idea/workspace.xml @@ -1,17 +1,13 @@ - - - - - + - + @@ -65,15 +61,4 @@ true - - - - - file://$PROJECT_DIR$/plugin_bilibili/live_info.go - 38 - - - - \ No newline at end of file From 08b0cca9e4f6d1b34fbfbb2089d8d1e96934fcaf Mon Sep 17 00:00:00 2001 From: Suika99 <290760339@qq.com> Date: Fri, 2 Jul 2021 01:00:09 +0800 Subject: [PATCH 04/79] test push --- .idea/workspace.xml | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/.idea/workspace.xml b/.idea/workspace.xml index fd386a1b..893f69c4 100644 --- a/.idea/workspace.xml +++ b/.idea/workspace.xml @@ -27,6 +27,12 @@ + + + + + + From 60dbd0d57970b2eb3c80e1f26fcbf27303b3c825 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 2 Jul 2021 17:19:41 +0800 Subject: [PATCH 05/79] =?UTF-8?q?=E6=A8=A1=E5=9D=97=E5=8C=96rand=5Fimage?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 3 +- README.md | 2 +- go.mod | 5 +- go.sum | 9 ++- main.go | 7 +- plugin_rand_image/classify.go | 111 -------------------------------- plugin_rand_image/rand_image.go | 102 +---------------------------- plugin_setutime/setu_geter.go | 2 +- 8 files changed, 17 insertions(+), 224 deletions(-) delete mode 100644 plugin_rand_image/classify.go diff --git a/.gitignore b/.gitignore index bed9a349..e5aa424d 100644 --- a/.gitignore +++ b/.gitignore @@ -1,4 +1,5 @@ data/SetuTime/cache data/SetuTime/search data/manager -.idea/ \ No newline at end of file +.idea/ +.DS_Store \ No newline at end of file diff --git a/README.md b/README.md index 13105f05..46a27e34 100644 --- a/README.md +++ b/README.md @@ -79,7 +79,7 @@ - 搜图 `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_saucenao"` - [x] 以图搜图|搜索图片|以图识图[图片] - [x] 搜图[P站图片ID] -- 简易随机图片(调用url) `github.com/FloatTech/ZeroBot-Plugin/plugin_rand_image` +- 随机图片与点评 `github.com/FloatTech/ZeroBot-Plugin/plugin_rand_image` - [x] 随机图片 - [x] 直接随机(无r18检测,后果自负) - [x] 设置随机图片网址[url] diff --git a/go.mod b/go.mod index 1243d0c5..51b0b158 100644 --- a/go.mod +++ b/go.mod @@ -4,14 +4,15 @@ go 1.16 require ( github.com/FloatTech/AnimeAPI v0.0.0-20210619112022-a8fdd4fefc07 + github.com/FloatTech/ZeroBot-ACGImage v1.1.2 github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.2 github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46 // indirect github.com/go-ole/go-ole v1.2.5 // indirect github.com/robfig/cron v1.2.0 - github.com/shirou/gopsutil v3.21.5+incompatible + github.com/shirou/gopsutil v3.21.6+incompatible github.com/sirupsen/logrus v1.8.1 github.com/t-tomalak/logrus-easy-formatter v0.0.0-20190827215021-c074f06c5816 - github.com/tidwall/gjson v1.8.0 + github.com/tidwall/gjson v1.8.1 github.com/tklauser/go-sysconf v0.3.6 // indirect github.com/wdvxdr1123/ZeroBot v1.2.1 modernc.org/sqlite v1.11.1 diff --git a/go.sum b/go.sum index 0b81351c..ebd0600a 100644 --- a/go.sum +++ b/go.sum @@ -1,5 +1,7 @@ github.com/FloatTech/AnimeAPI v0.0.0-20210619112022-a8fdd4fefc07 h1:7fBPLLoZysaa9PI9ApgzyVMrMLMWBam273YgKwy7Ddg= github.com/FloatTech/AnimeAPI v0.0.0-20210619112022-a8fdd4fefc07/go.mod h1:GYrQD70HvBzry1XiZ1tHFNOsOqRkR+ao4XGYZqV4I9c= +github.com/FloatTech/ZeroBot-ACGImage v1.1.2 h1:Q+FwOb1vCCYG2B7hPU0uBMzWwB85eVlC0pWRJZ+rBCQ= +github.com/FloatTech/ZeroBot-ACGImage v1.1.2/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.2 h1:I7RSCsJVT6elehdaSiWB4n96y06fQxMsvAG494S5Od0= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.2/go.mod h1:femu/wVuqVSN/rg209qksMx8/2OKUF8l1PZCNg4RwVA= github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46 h1:5sXbqlSomvdjlRbWyNqkPsJ3Fg+tQZCbgeX1VGljbQY= @@ -53,8 +55,8 @@ github.com/remyoudompheng/bigfft v0.0.0-20200410134404-eec4a21b6bb0 h1:OdAsTTz6O github.com/remyoudompheng/bigfft v0.0.0-20200410134404-eec4a21b6bb0/go.mod h1:qqbHyh8v60DhA7CoWK5oRCqLrMHRGoxYCSS9EjAz6Eo= github.com/robfig/cron v1.2.0 h1:ZjScXvvxeQ63Dbyxy76Fj3AT3Ut0aKsyd2/tl3DTMuQ= github.com/robfig/cron v1.2.0/go.mod h1:JGuDeoQd7Z6yL4zQhZ3OPEVHB7fL6Ka6skscFHfmt2k= -github.com/shirou/gopsutil v3.21.5+incompatible h1:OloQyEerMi7JUrXiNzy8wQ5XN+baemxSl12QgIzt0jc= -github.com/shirou/gopsutil v3.21.5+incompatible/go.mod h1:5b4v6he4MtMOwMlS0TUMTu2PcXUg8+E1lC7eC3UO/RA= +github.com/shirou/gopsutil v3.21.6+incompatible h1:mmZtAlWSd8U2HeRTjswbnDLPxqsEoK01NK+GZ1P+nEM= +github.com/shirou/gopsutil v3.21.6+incompatible/go.mod h1:5b4v6he4MtMOwMlS0TUMTu2PcXUg8+E1lC7eC3UO/RA= github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6MwdIuYE2rE= github.com/sirupsen/logrus v1.8.1 h1:dJKuHgqk1NNQlqoA6BTlM1Wf9DOH3NBjQyu0h9+AZZE= github.com/sirupsen/logrus v1.8.1/go.mod h1:yWOB1SBYBC5VeMP7gHvWumXLIWorT60ONWic61uBYv0= @@ -67,8 +69,9 @@ github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/ github.com/syndtr/goleveldb v1.0.0/go.mod h1:ZVVdQEZoIme9iO1Ch2Jdy24qqXrMMOU6lpPAyBWyWuQ= github.com/t-tomalak/logrus-easy-formatter v0.0.0-20190827215021-c074f06c5816 h1:J6v8awz+me+xeb/cUTotKgceAYouhIB3pjzgRd6IlGk= github.com/t-tomalak/logrus-easy-formatter v0.0.0-20190827215021-c074f06c5816/go.mod h1:tzym/CEb5jnFI+Q0k4Qq3+LvRF4gO3E2pxS8fHP8jcA= -github.com/tidwall/gjson v1.8.0 h1:Qt+orfosKn0rbNTZqHYDqBrmm3UDA4KRkv70fDzG+PQ= github.com/tidwall/gjson v1.8.0/go.mod h1:5/xDoumyyDNerp2U36lyolv46b3uF/9Bu6OfyQ9GImk= +github.com/tidwall/gjson v1.8.1 h1:8j5EE9Hrh3l9Od1OIEDAb7IpezNA20UdRngNAj5N0WU= +github.com/tidwall/gjson v1.8.1/go.mod h1:5/xDoumyyDNerp2U36lyolv46b3uF/9Bu6OfyQ9GImk= github.com/tidwall/match v1.0.3 h1:FQUVvBImDutD8wJLN6c5eMzWtjgONK9MwIBCOrUJKeE= github.com/tidwall/match v1.0.3/go.mod h1:eRSPERbgtNPcGhD8UCthc6PmLEQXEWd3PRB5JTxsfmM= github.com/tidwall/pretty v1.1.0 h1:K3hMW5epkdAVwibsQEfR/7Zj0Qgt4DxtNumTq/VloO8= diff --git a/main.go b/main.go index 69ed8aaa..519cd99d 100644 --- a/main.go +++ b/main.go @@ -2,6 +2,7 @@ package main import ( "fmt" + "os" // 注:以下插件均可通过前面加 // 注释,注释后停用并不加载插件 // 下列插件可与 wdvxdr1123/ZeroBot v1.1.2 以上配合单独使用 @@ -19,8 +20,6 @@ import ( _ "github.com/FloatTech/ZeroBot-Plugin/plugin_music" // 点歌 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_shindan" // 测定 - //_ "github.com/FloatTech/ZeroBot-ACGImage" //简易随机图片 - // b站相关 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_bilibili" // 查询b站用户信息 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_diana" // 嘉心糖发病 @@ -28,7 +27,7 @@ import ( // 二次元图片 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_image_finder" // 关键字搜图 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_lolicon" // lolicon 随机图片 - _ "github.com/FloatTech/ZeroBot-Plugin/plugin_rand_image" // 随机图片 + _ "github.com/FloatTech/ZeroBot-Plugin/plugin_rand_image" // 随机图片与点评 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_saucenao" // 以图搜图 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_setutime" // 来份涩图 @@ -61,7 +60,7 @@ func main() { zero.Run(zero.Config{ NickName: []string{"椛椛", "ATRI", "atri", "亚托莉", "アトリ"}, CommandPrefix: "/", - SuperUsers: []string{"213864964"}, // 必须修改,否则无权限 + SuperUsers: os.Args[1:], // 必须修改,否则无权限 Driver: []zero.Driver{ &driver.WSClient{ Url: "ws://127.0.0.1:6700", diff --git a/plugin_rand_image/classify.go b/plugin_rand_image/classify.go deleted file mode 100644 index 9351a169..00000000 --- a/plugin_rand_image/classify.go +++ /dev/null @@ -1,111 +0,0 @@ -package plugin_rand_image - -import ( - "fmt" - "io/ioutil" - "net/http" - "net/url" - "os" - "strconv" - - zero "github.com/wdvxdr1123/ZeroBot" - "github.com/wdvxdr1123/ZeroBot/message" - - "github.com/tidwall/gjson" -) - -var ( - CACHE_IMG_FILE = "/tmp/setugt" - CACHE_URI = "file:///" + CACHE_IMG_FILE - VOTE_API_URL = "http://saki.fumiama.top/vote?uuid=零号&img=%s&class=%d" - CLASSIFY_HEAD = "http://saki.fumiama.top:62002/dice?url=" - MsgofGrp = make(map[int64]int64) - dhashofmsg = make(map[int64]string) -) - -func Classify(ctx *zero.Ctx, targeturl string, noimg bool) { - get_url := CLASSIFY_HEAD + url.QueryEscape(targeturl) - if noimg { - get_url += "&noimg=true" - } - resp, err := http.Get(get_url) - if err != nil { - ctx.Send(fmt.Sprintf("ERROR: %v", err)) - } else { - if noimg { - data, err1 := ioutil.ReadAll(resp.Body) - if err1 == nil { - dhash := gjson.GetBytes(data, "img").String() - class := int(gjson.GetBytes(data, "class").Int()) - replyClass(ctx, dhash, class, noimg) - } else { - ctx.Send(fmt.Sprintf("ERROR: %v", err1)) - } - } else { - class, err1 := strconv.Atoi(resp.Header.Get("Class")) - dhash := resp.Header.Get("DHash") - if err1 != nil { - ctx.Send(fmt.Sprintf("ERROR: %v", err1)) - } - defer resp.Body.Close() - // 写入文件 - data, _ := ioutil.ReadAll(resp.Body) - f, _ := os.OpenFile(CACHE_IMG_FILE, os.O_WRONLY|os.O_TRUNC|os.O_CREATE, 0644) - defer f.Close() - f.Write(data) - replyClass(ctx, dhash, class, noimg) - } - } -} - -func Vote(ctx *zero.Ctx, class int) { - msg, ok := MsgofGrp[ctx.Event.GroupID] - if ok { - ctx.DeleteMessage(msg) - delete(MsgofGrp, ctx.Event.GroupID) - dhash, ok2 := dhashofmsg[msg] - if ok2 { - http.Get(fmt.Sprintf(VOTE_API_URL, dhash, class)) - delete(dhashofmsg, msg) - } - } -} - -func replyClass(ctx *zero.Ctx, dhash string, class int, noimg bool) { - if class > 4 { - switch class { - case 5: - ctx.Send("[5]影响不好啦!") - case 6: - ctx.Send("[6]太涩啦,🐛了!") - } - if dhash != "" && !noimg { - b14, err3 := url.QueryUnescape(dhash) - if err3 == nil { - ctx.Send("给你点提示哦:" + b14) - } - } - } else { - var last_message_id int64 - if !noimg { - last_message_id = ctx.SendChain(message.Image(CACHE_URI).Add("no_cache", "0")) - last_group_id := ctx.Event.GroupID - MsgofGrp[last_group_id] = last_message_id - dhashofmsg[last_message_id] = dhash - } else { - last_message_id = ctx.Event.MessageID - } - switch class { - case 0: - ctx.SendChain(message.Reply(last_message_id), message.Text("[0]一堆像素点")) - case 1: - ctx.SendChain(message.Reply(last_message_id), message.Text("[1]普通")) - case 2: - ctx.SendChain(message.Reply(last_message_id), message.Text("[2]有点意思")) - case 3: - ctx.SendChain(message.Reply(last_message_id), message.Text("[3]不错")) - case 4: - ctx.SendChain(message.Reply(last_message_id), message.Text("[4]我好啦!")) - } - } -} diff --git a/plugin_rand_image/rand_image.go b/plugin_rand_image/rand_image.go index ce38e597..a601902e 100644 --- a/plugin_rand_image/rand_image.go +++ b/plugin_rand_image/rand_image.go @@ -1,105 +1,5 @@ package plugin_rand_image import ( - "fmt" - "strings" - "time" - - zero "github.com/wdvxdr1123/ZeroBot" - "github.com/wdvxdr1123/ZeroBot/message" + _ "github.com/FloatTech/ZeroBot-ACGImage" //简易随机图片 ) - -var ( - RANDOM_API_URL = "https://api.pixivweb.com/anime18r.php?return=img" - BLOCK_REQUEST = false -) - -func init() { // 插件主体 - zero.OnRegex(`^设置随机图片网址(.*)$`, zero.SuperUserPermission).SetBlock(true).SetPriority(20). - Handle(func(ctx *zero.Ctx) { - url := ctx.State["regex_matched"].([]string)[1] - if !strings.HasPrefix(url, "http") { - ctx.Send("URL非法!") - } else { - RANDOM_API_URL = url - } - return - }) - // 有保护的随机图片 - zero.OnFullMatch("随机图片").SetBlock(true).SetPriority(24). - Handle(func(ctx *zero.Ctx) { - if ctx.Event.GroupID > 0 { - Classify(ctx, RANDOM_API_URL, false) - } - return - }) - // 直接随机图片,危险,仅管理员可用 - zero.OnFullMatch("直接随机", zero.AdminPermission).SetBlock(true).SetPriority(24). - Handle(func(ctx *zero.Ctx) { - if ctx.Event.GroupID > 0 { - if BLOCK_REQUEST { - ctx.Send("请稍后再试哦") - } else { - BLOCK_REQUEST = true - last_message_id := ctx.SendChain(message.Image(RANDOM_API_URL).Add("cache", "0")) - last_group_id := ctx.Event.GroupID - MsgofGrp[last_group_id] = last_message_id - BLOCK_REQUEST = false - } - } - return - }) - // 撤回最后的随机图片 - zero.OnFullMatch("不许好").SetBlock(true).SetPriority(24). - Handle(func(ctx *zero.Ctx) { - Vote(ctx, 5) - }) - // 撤回最后的随机图片 - zero.OnFullMatch("太涩了").SetBlock(true).SetPriority(24). - Handle(func(ctx *zero.Ctx) { - Vote(ctx, 6) - }) - // 上传一张图进行评价 - zero.OnFullMatch("评价图片").SetBlock(true).SetPriority(24). - Handle(func(ctx *zero.Ctx) { - // 匹配图片 - rule := func() zero.Rule { - return func(ctx *zero.Ctx) bool { - var urls = []string{} - for _, elem := range ctx.Event.Message { - if elem.Type == "image" { - urls = append(urls, elem.Data["url"]) - } - } - if len(urls) > 0 { - ctx.State["image_url"] = urls - return true - } - return false - } - } - // 索取图片 - ctx.SendChain(message.Text("请发送一张图片")) - next := zero.NewFutureEvent("message", 999, false, zero.CheckUser(ctx.Event.UserID), rule()) - recv, cancel := next.Repeat() - select { - case <-time.After(time.Second * 120): - return - case e := <-recv: - cancel() - newCtx := &zero.Ctx{Event: e, State: zero.State{}} - if rule()(newCtx) { - ctx.State["image_url"] = newCtx.State["image_url"] - } - } - if ctx.Event.GroupID > 0 { - ctx.Send("少女祈祷中......") - for _, pic := range ctx.State["image_url"].([]string) { - fmt.Println(pic) - Classify(ctx, pic, true) - } - } - return - }) - -} diff --git a/plugin_setutime/setu_geter.go b/plugin_setutime/setu_geter.go index 2ceba9a3..a2e00cf8 100644 --- a/plugin_setutime/setu_geter.go +++ b/plugin_setutime/setu_geter.go @@ -38,7 +38,7 @@ func NewPools() *Pool { Pool: map[string][]*pixiv.Illust{}, Form: 0, } - err := os.MkdirAll(cache.Path, 0644) + err := os.MkdirAll(cache.Path, 0755) if err != nil { panic(err) } From f8ccb467bac89f59451adbfb37e46e0fd7ed76e6 Mon Sep 17 00:00:00 2001 From: Suika99 <290760339@qq.com> Date: Fri, 2 Jul 2021 19:06:01 +0800 Subject: [PATCH 06/79] =?UTF-8?q?=E4=BF=AE=E4=BA=86=E4=B8=AAbody=E5=8C=85?= =?UTF-8?q?=E6=95=B0=E6=8D=AE=E4=B8=BA=E7=A9=BA=E7=9A=84bug=EF=BC=8C?= =?UTF-8?q?=E8=99=BD=E7=84=B6=E4=B8=8D=E7=9F=A5=E9=81=93=E5=8F=91=E7=94=9F?= =?UTF-8?q?=E4=BA=86=E5=95=A5=EF=BC=8C=E4=BD=86=E5=AE=83=E7=A1=AE=E5=AE=9E?= =?UTF-8?q?=E6=98=AF=E8=A2=AB=E4=BF=AE=E5=A5=BD=E4=BA=86?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .idea/workspace.xml | 70 +++++++++++++++++++++++++++++++++--- plugin_ai_false/ai_false.go | 2 +- plugin_bilibili/fansDaily.go | 14 ++++---- plugin_bilibili/info.go | 41 ++++++++++----------- plugin_bilibili/live_info.go | 37 +++++++------------ 5 files changed, 108 insertions(+), 56 deletions(-) diff --git a/.idea/workspace.xml b/.idea/workspace.xml index fd386a1b..232c490e 100644 --- a/.idea/workspace.xml +++ b/.idea/workspace.xml @@ -1,13 +1,19 @@ - + + + + + + + - + @@ -26,7 +32,12 @@ - + + + + + + @@ -38,7 +49,16 @@ - + + + + + + + + + + @@ -48,8 +68,38 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -58,6 +108,18 @@ + + + true diff --git a/plugin_ai_false/ai_false.go b/plugin_ai_false/ai_false.go index b0421852..0dffa3f6 100644 --- a/plugin_ai_false/ai_false.go +++ b/plugin_ai_false/ai_false.go @@ -16,7 +16,7 @@ import ( ) func init() { // 插件主体 - zero.OnFullMatchGroup([]string{"检查身体", "自检", "启动自检", "系统状态"}, zero.AdminPermission). + zero.OnFullMatchGroup([]string{"检查身体", "自检", "启动自检", "系统状态"}). Handle(func(ctx *zero.Ctx) { ctx.SendChain(message.Text( "* CPU占用率: ", getCpuPercent(), "%\n", diff --git a/plugin_bilibili/fansDaily.go b/plugin_bilibili/fansDaily.go index 7a1f97a7..84321c91 100644 --- a/plugin_bilibili/fansDaily.go +++ b/plugin_bilibili/fansDaily.go @@ -39,11 +39,11 @@ func FansDaily(groupID int64) { func fansData(groupID int64) { zero.RangeBot(func(id int64, ctx *zero.Ctx) bool { var ( - diana = fensiapi("672328094") - ava = fensiapi("672346917") - eileen = fensiapi("672342685") - bella = fensiapi("672353429") - carol = fensiapi("351609538") + diana = fansapi("672328094") + ava = fansapi("672346917") + eileen = fansapi("672342685") + bella = fansapi("672353429") + carol = fansapi("351609538") ) ctx.SendGroupMessage( groupID, @@ -104,7 +104,7 @@ func fansData(groupID int64) { } // 请求api -func fensiapi(uid string) *follower { +func fansapi(uid string) *follower { url := "https://api.vtbs.moe/v1/detail/" + uid resp, err := http.Get(url) @@ -117,4 +117,4 @@ func fensiapi(uid string) *follower { panic(err) } return result -} \ No newline at end of file +} diff --git a/plugin_bilibili/info.go b/plugin_bilibili/info.go index c394cb88..fd3b7042 100644 --- a/plugin_bilibili/info.go +++ b/plugin_bilibili/info.go @@ -1,52 +1,53 @@ package plugin_bilibili import ( - "fmt" - "io/ioutil" - "net/http" - "github.com/tidwall/gjson" zero "github.com/wdvxdr1123/ZeroBot" "github.com/wdvxdr1123/ZeroBot/message" + "io/ioutil" + "net/http" ) +// 查成分的 func init() { zero.OnRegex(`^>user info\s(.{1,25})$`). Handle(func(ctx *zero.Ctx) { keyword := ctx.State["regex_matched"].([]string)[1] - res, err := uid(keyword) + rest, err := uid(keyword) if err != nil { ctx.SendChain(message.Text("ERROR: ", err)) return } - id := res.Get("data.result.0.mid").Int() - url := fmt.Sprintf("https://api.bilibili.com/x/relation/same/followings?vmid=%d", id) + id := rest.Get("data.result.0.mid").String() + url := "https://api.bilibili.com/x/relation/same/followings?vmid=" + id + method := "GET" client := &http.Client{} - req, err := http.NewRequest("GET", url, nil) + req, err := http.NewRequest(method, url, nil) if err != nil { ctx.SendChain(message.Text("ERROR: ", err)) return } req.Header.Add("cookie", "CURRENT_FNVAL=80; _uuid=772B88E8-3ED1-D589-29BB-F6CB5214239A06137infoc; blackside_state=1; bfe_id=6f285c892d9d3c1f8f020adad8bed553; rpdid=|(umY~Jkl|kJ0J'uYkR|)lu|); fingerprint=0ec2b1140fb30b56d7b5e415bc3b5fb1; buvid_fp=C91F5265-3DF4-4D5A-9FF3-C546370B14C0143096infoc; buvid_fp_plain=C91F5265-3DF4-4D5A-9FF3-C546370B14C0143096infoc; SESSDATA=9e0266f6%2C1639637127%2Cb0172%2A61; bili_jct=96ddbd7e22d527abdc0501339a12d4d3; DedeUserID=695737880; DedeUserID__ckMd5=0117660e75db7b01; sid=5labuhaf; PVID=1; bfe_id=1e33d9ad1cb29251013800c68af42315") - resp, err := client.Do(req) + res, err := client.Do(req) if err != nil { ctx.SendChain(message.Text("ERROR: ", err)) return } - resp.Body.Close() - if resp.StatusCode != http.StatusOK { - ctx.SendChain(message.Text("ERROR: code ", resp.StatusCode)) + defer res.Body.Close() + + body, err := ioutil.ReadAll(res.Body) + if err != nil { + ctx.SendChain(message.Text("ERROR: ", err)) return } - data, _ := ioutil.ReadAll(resp.Body) - json := gjson.ParseBytes(data) + data := string(body) ctx.SendChain(message.Text( - "uid: ", res.Get("data.result.0.mid").Int(), "\n", - "name: ", res.Get("data.result.0.uname").Str, "\n", - "sex: ", []string{"", "", "女", "男"}[res.Get("data.result.0.gender").Int()], "\n", - "sign: ", res.Get("data.result.0.usign").Str, "\n", - "level: ", res.Get("data.result.0.level").Int(), "\n", - "follow: ", json.Get("data.list.#.uname"), + "uid: ", rest.Get("data.result.0.mid").Int(), "\n", + "name: ", rest.Get("data.result.0.uname").Str, "\n", + "sex: ", []string{"", "", "女", "男"}[rest.Get("data.result.0.gender").Int()], "\n", + "sign: ", rest.Get("data.result.0.usign").Str, "\n", + "level: ", rest.Get("data.result.0.level").Int(), "\n", + "follow: ", gjson.Get(data, "data.list.#.uname"), )) }) } diff --git a/plugin_bilibili/live_info.go b/plugin_bilibili/live_info.go index 68b348ff..60845cb6 100644 --- a/plugin_bilibili/live_info.go +++ b/plugin_bilibili/live_info.go @@ -2,7 +2,6 @@ package plugin_bilibili import ( "errors" - "fmt" "io/ioutil" "net/http" "time" @@ -12,6 +11,7 @@ import ( "github.com/wdvxdr1123/ZeroBot/message" ) +// 查vup粉丝数据 func init() { zero.OnRegex(`^>vup info\s?(.{1,25})$`). Handle(func(ctx *zero.Ctx) { @@ -21,36 +21,25 @@ func init() { ctx.SendChain(message.Text("ERROR: ", err)) return } - id := res.Get("data.result.0.mid").Int() + id := res.Get("data.result.0.mid").String() // 获取详情 - api := fmt.Sprintf("https://api.vtbs.moe/v1/detail/%d", id) - resp, err := http.Get(api) - if err != nil { - ctx.SendChain(message.Text("ERROR: ", err)) - return - } - resp.Body.Close() - if resp.StatusCode != http.StatusOK { - ctx.SendChain(message.Text("ERROR: code ", resp.StatusCode)) - return - } - data, _ := ioutil.ReadAll(resp.Body) - json := gjson.ParseBytes(data) + json := fansapi(id) ctx.SendChain(message.Text( - "uid: ", json.Get("mid").Int(), "\n", - "名字: ", json.Get("uname").Str, "\n", - "当前粉丝数: ", json.Get("follower").Int(), "\n", - "24h涨粉数: ", json.Get("rise").Int(), "\n", - "视频投稿数: ", json.Get("video").Int(), "\n", - "直播间id: ", json.Get("roomid").Int(), "\n", - "舰队: ", json.Get("guardNum").Int(), "\n", - "直播总排名: ", json.Get("areaRank").Int(), "\n", - "数据来源: ", "https://vtbs.moe/detail/", uid, "\n", + "uid: ", json.Mid, "\n", + "名字: ", json.Uname, "\n", + "当前粉丝数: ", json.Follower, "\n", + "24h涨粉数: ", json.Rise, "\n", + "视频投稿数: ", json.Video, "\n", + "直播间id: ", json.Roomid, "\n", + "舰队: ", json.GuardNum, "\n", + "直播总排名: ", json.AreaRank, "\n", + "数据来源: ", "https://vtbs.moe/detail/", json.Mid, "\n", "数据获取时间: ", time.Now().Format("2006-01-02 15:04:05"), )) }) } +// 搜索api:通过把触发指令传入的昵称找出uid返回 func uid(keyword string) (gjson.Result, error) { api := "http://api.bilibili.com/x/web-interface/search/type?search_type=bili_user&&user_type=1&keyword=" + keyword resp, err := http.Get(api) From 098e81d1c81b9b02a57883ed1cb4264a5687e2bc Mon Sep 17 00:00:00 2001 From: Suika99 <290760339@qq.com> Date: Fri, 2 Jul 2021 19:08:59 +0800 Subject: [PATCH 07/79] =?UTF-8?q?=E4=BF=AE=E4=BA=86=E4=B8=AAbody=E5=8C=85?= =?UTF-8?q?=E6=95=B0=E6=8D=AE=E4=B8=BA=E7=A9=BA=E7=9A=84bug=EF=BC=8C?= =?UTF-8?q?=E8=99=BD=E7=84=B6=E4=B8=8D=E7=9F=A5=E9=81=93=E5=8F=91=E7=94=9F?= =?UTF-8?q?=E4=BA=86=E5=95=A5=EF=BC=8C=E4=BD=86=E5=AE=83=E7=A1=AE=E5=AE=9E?= =?UTF-8?q?=E6=98=AF=E8=A2=AB=E4=BF=AE=E5=A5=BD=E4=BA=86?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .idea/workspace.xml | 12 +++++------- plugin_ai_false/ai_false.go | 2 +- 2 files changed, 6 insertions(+), 8 deletions(-) diff --git a/.idea/workspace.xml b/.idea/workspace.xml index 232c490e..bbc0bff8 100644 --- a/.idea/workspace.xml +++ b/.idea/workspace.xml @@ -1,13 +1,7 @@ - - - - - - - + + + + true diff --git a/plugin_ai_false/ai_false.go b/plugin_ai_false/ai_false.go index 0dffa3f6..b0421852 100644 --- a/plugin_ai_false/ai_false.go +++ b/plugin_ai_false/ai_false.go @@ -16,7 +16,7 @@ import ( ) func init() { // 插件主体 - zero.OnFullMatchGroup([]string{"检查身体", "自检", "启动自检", "系统状态"}). + zero.OnFullMatchGroup([]string{"检查身体", "自检", "启动自检", "系统状态"}, zero.AdminPermission). Handle(func(ctx *zero.Ctx) { ctx.SendChain(message.Text( "* CPU占用率: ", getCpuPercent(), "%\n", From eb08d29e3d2f0360a88d35b18df2909fda139875 Mon Sep 17 00:00:00 2001 From: Kanri Date: Fri, 2 Jul 2021 19:20:55 +0800 Subject: [PATCH 08/79] =?UTF-8?q?=F0=9F=94=96=E2=9C=8F=EF=B8=8F=20?= =?UTF-8?q?=E6=B7=BB=E5=8A=A0=E6=B3=A8=E9=87=8A?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- main.go | 39 ++++++++++++++++++++++++--------------- 1 file changed, 24 insertions(+), 15 deletions(-) diff --git a/main.go b/main.go index 519cd99d..ed135ea4 100644 --- a/main.go +++ b/main.go @@ -3,6 +3,7 @@ package main import ( "fmt" "os" + "strings" // 注:以下插件均可通过前面加 // 注释,注释后停用并不加载插件 // 下列插件可与 wdvxdr1123/ZeroBot v1.1.2 以上配合单独使用 @@ -40,6 +41,13 @@ import ( easy "github.com/t-tomalak/logrus-easy-formatter" ) +var content = []string{ + "* OneBot + ZeroBot + Golang ", + "* Version 1.0.4 - 2021-07-02 19:14:58.581489207 +0800 CST", + "* Copyright © 2020 - 2021 Kanri, DawnNights, Fumiama ", + "* Project: https://github.com/FloatTech/ZeroBot-Plugin", +} + func init() { log.SetFormatter(&easy.Formatter{ TimestampFormat: "2006-01-02 15:04:05", @@ -49,34 +57,35 @@ func init() { } func main() { - fmt.Print(` -====================[ZeroBot-Plugin]==================== -* OneBot + ZeroBot + Golang -* Version 1.0.3 - 2021-05-02 18:50:40.5489203 +0800 CST -* Copyright © 2021 Kanri, DawnNights, Fumiama -* Project: https://github.com/FloatTech/ZeroBot-Plugin -======================================================== -`) // 启动打印 + fmt.Print( + "====================[ZeroBot-Plugin]====================", + "\n", strings.Join(content, "\n"), "\n", + "========================================================", + ) // 启动打印 zero.Run(zero.Config{ NickName: []string{"椛椛", "ATRI", "atri", "亚托莉", "アトリ"}, CommandPrefix: "/", - SuperUsers: os.Args[1:], // 必须修改,否则无权限 + + // SuperUsers 某些功能需要主人权限,可通过以下两种方式修改 + // []string{}:通过代码写死的方式添加主人账号 + // os.Args[1:]:通过命令行参数的方式添加主人账号 + SuperUsers: append([]string{"12345678", "87654321"}, os.Args[1:]...), + Driver: []zero.Driver{ &driver.WSClient{ + // OneBot 正向WS 默认使用 6700 端口 Url: "ws://127.0.0.1:6700", AccessToken: "", }, }, }) + // 帮助 zero.OnFullMatchGroup([]string{"help", "/help", ".help", "菜单", "帮助"}, zero.OnlyToMe).SetBlock(true).SetPriority(999). Handle(func(ctx *zero.Ctx) { - ctx.SendChain(message.Text( - "* OneBot + ZeroBot + Golang ", "\n", - "* Version 1.0.3 - 2021-05-02 18:50:40.5489203 +0800 CST", "\n", - "* Copyright © 2021 Kanri, DawnNights, Fumiama ", "\n", - "* Project: https://github.com/FloatTech/ZeroBot-Plugin", - )) + ctx.SendChain( + message.Text(strings.Join(content, "\n")), + ) }) select {} } From 5bee89098068ef724157a0c61d52d3f906bcf9fb Mon Sep 17 00:00:00 2001 From: Kanri Date: Fri, 2 Jul 2021 19:52:30 +0800 Subject: [PATCH 09/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_ai_false/ai_false.go | 12 ++++++------ plugin_atri/atri.go | 11 +++++++---- plugin_bilibili/fansDaily.go | 9 +++++---- plugin_chat/chat.go | 5 +---- plugin_image_finder/keyword.go | 4 ++-- plugin_manager/manager.go | 2 +- plugin_music/selecter.go | 4 ++-- plugin_runcode/code_runner.go | 8 ++++---- 8 files changed, 28 insertions(+), 27 deletions(-) diff --git a/plugin_ai_false/ai_false.go b/plugin_ai_false/ai_false.go index b0421852..6d370f7d 100644 --- a/plugin_ai_false/ai_false.go +++ b/plugin_ai_false/ai_false.go @@ -19,25 +19,25 @@ func init() { // 插件主体 zero.OnFullMatchGroup([]string{"检查身体", "自检", "启动自检", "系统状态"}, zero.AdminPermission). Handle(func(ctx *zero.Ctx) { ctx.SendChain(message.Text( - "* CPU占用率: ", getCpuPercent(), "%\n", - "* RAM占用率: ", getMemPercent(), "%\n", - "* 硬盘活动率: ", getDiskPercent(), "%", + "* CPU占用率: ", cpuPercent(), "%\n", + "* RAM占用率: ", memPercent(), "%\n", + "* 硬盘活动率: ", diskPercent(), "%", ), ) }) } -func getCpuPercent() float64 { +func cpuPercent() float64 { percent, _ := cpu.Percent(time.Second, false) return math.Round(percent[0]) } -func getMemPercent() float64 { +func memPercent() float64 { memInfo, _ := mem.VirtualMemory() return math.Round(memInfo.UsedPercent) } -func getDiskPercent() float64 { +func diskPercent() float64 { parts, _ := disk.Partitions(true) diskInfo, _ := disk.Usage(parts[0].Mountpoint) return math.Round(diskInfo.UsedPercent) diff --git a/plugin_atri/atri.go b/plugin_atri/atri.go index 6d943191..fd11ead9 100644 --- a/plugin_atri/atri.go +++ b/plugin_atri/atri.go @@ -1,3 +1,4 @@ +// Package atri // 本文件基于 https://github.com/Kyomotoi/ATRI // 为 Golang 移植版,语料、素材均来自上述项目 // 本项目遵守 AGPL v3 协议进行开源 @@ -12,8 +13,11 @@ import ( ) var ( - PRIO = -1 - RES = "https://raw.dihe.moe/Yiwen-Chan/ZeroBot-Plugin/master/plugin_atri/" + // ATRI 所有命令的优先级 + PRIO = -1 + // ATRI 表情的 GitHub 镜像位置 + RES = "https://raw.dihe.moe/Yiwen-Chan/ZeroBot-Plugin/master/plugin_atri/" + // ATRI 的总开关 ENABLE = true ) @@ -89,8 +93,7 @@ func init() { // 插件主体 zero.OnFullMatchGroup([]string{"中午好", "午安"}, AtriSwitch()).SetBlock(true).SetPriority(PRIO). Handle(func(ctx *zero.Ctx) { now := time.Now().Hour() - switch { - case now < 6: // 凌晨 + if now > 11 && now < 15 { // 中午 ctx.SendChain(randText( "午安w", "午觉要好好睡哦,ATRI会陪伴在你身旁的w", diff --git a/plugin_bilibili/fansDaily.go b/plugin_bilibili/fansDaily.go index 84321c91..ec7ba86f 100644 --- a/plugin_bilibili/fansDaily.go +++ b/plugin_bilibili/fansDaily.go @@ -2,11 +2,12 @@ package plugin_bilibili import ( "encoding/json" + "net/http" + "time" + "github.com/robfig/cron" zero "github.com/wdvxdr1123/ZeroBot" "github.com/wdvxdr1123/ZeroBot/message" - "net/http" - "time" ) type follower struct { @@ -24,14 +25,14 @@ type follower struct { func init() { zero.OnFullMatch("/开启粉丝日报", zero.AdminPermission). Handle(func(ctx *zero.Ctx) { - FansDaily(130591566) //群号传进去给下面发信息的函数 + FansDaily(130591566) // 群号传进去给下面发信息的函数 }) } // 定时任务每天晚上最后2分钟执行一次 func FansDaily(groupID int64) { c := cron.New() - c.AddFunc("0 58 23 * * ?", func() { fansData(groupID) }) + _ = c.AddFunc("0 58 23 * * ?", func() { fansData(groupID) }) c.Start() } diff --git a/plugin_chat/chat.go b/plugin_chat/chat.go index 61f9544d..38d7489f 100644 --- a/plugin_chat/chat.go +++ b/plugin_chat/chat.go @@ -1,4 +1,5 @@ /* +Package plugin_chat 对话插件 example */ package plugin_chat @@ -74,13 +75,11 @@ func init() { // 插件主体 "❄️风速中", "\n", "群温度 ", AirConditTemp[ctx.Event.GroupID], "℃", )) - return } else { ctx.SendChain(message.Text( "💤", "\n", "群温度 ", AirConditTemp[ctx.Event.GroupID], "℃", )) - return } }) zero.OnFullMatch(`群温度`).SetBlock(true).FirstPriority(). @@ -93,13 +92,11 @@ func init() { // 插件主体 "❄️风速中", "\n", "群温度 ", AirConditTemp[ctx.Event.GroupID], "℃", )) - return } else { ctx.SendChain(message.Text( "💤", "\n", "群温度 ", AirConditTemp[ctx.Event.GroupID], "℃", )) - return } }) } diff --git a/plugin_image_finder/keyword.go b/plugin_image_finder/keyword.go index ae7f93b5..5cdf5013 100644 --- a/plugin_image_finder/keyword.go +++ b/plugin_image_finder/keyword.go @@ -70,7 +70,7 @@ func init() { } -// 请求api +// soutuapi 请求api func soutuapi(keyword string) *AutoGenerated { url := "https://api.pixivel.moe/pixiv?type=search&page=0&mode=partial_match_for_tags&word=" + keyword @@ -97,7 +97,7 @@ func soutuapi(keyword string) *AutoGenerated { return result } -//从json里的30条数据中随机获取一条返回 +// Suiji 从json里的30条数据中随机获取一条返回 func Suiji() int { rand.Seed(time.Now().UnixNano()) return rand.Intn(30) diff --git a/plugin_manager/manager.go b/plugin_manager/manager.go index 7bdd8457..18453e70 100644 --- a/plugin_manager/manager.go +++ b/plugin_manager/manager.go @@ -260,7 +260,7 @@ func init() { // 插件主体 if ok { t.Enable = false delete(*timer.Timers, ti) //避免重复取消 - timer.SaveTimers() + _ = timer.SaveTimers() ctx.Send("取消成功~") } else { ctx.Send("没有这个定时器哦~") diff --git a/plugin_music/selecter.go b/plugin_music/selecter.go index cf18d645..25e89c25 100644 --- a/plugin_music/selecter.go +++ b/plugin_music/selecter.go @@ -129,7 +129,7 @@ func kugou(keyword string) message.MessageSegment { // 返回音乐卡片 return message.CustomMusic( "https://www.kugou.com/song/#hash="+audio.Get("hash").Str+"&album_id="+audio.Get("album_id").Str, - strings.Replace(audio.Get("play_backup_url").Str, "\\/", "/", -1), + strings.ReplaceAll(audio.Get("play_backup_url").Str, "\\/", "/"), audio.Get("audio_name").Str, ).Add("content", audio.Get("author_name").Str).Add("image", audio.Get("img").Str) } @@ -202,7 +202,7 @@ func find(pre string, suf string, str string) string { if n == -1 { n = 0 } else { - n = n + len(pre) + n += len(pre) } str = str[n:] m := strings.Index(str, suf) diff --git a/plugin_runcode/code_runner.go b/plugin_runcode/code_runner.go index 0290e8e4..fdd7a36e 100644 --- a/plugin_runcode/code_runner.go +++ b/plugin_runcode/code_runner.go @@ -4,7 +4,7 @@ package plugin_runcode import ( - "fmt" + "errors" "io/ioutil" "net/http" "net/url" @@ -157,7 +157,7 @@ func init() { block = message.UnescapeCQCodeText(block) if block == "help" { - //输出模板 + // 输出模板 ctx.SendChain( message.Text("> ", ctx.Event.Sender.NickName, " ", language, "-template:\n"), message.Text( @@ -216,7 +216,7 @@ func runCode(code string, runType [2]string) (string, error) { } defer body.Body.Close() if body.StatusCode != http.StatusOK { - return "", fmt.Errorf("code %d", body.StatusCode) + return "", errors.New("code not 200") } res, err := ioutil.ReadAll(body.Body) if err != nil { @@ -225,7 +225,7 @@ func runCode(code string, runType [2]string) (string, error) { // 结果处理 content := gjson.ParseBytes(res) if e := content.Get("errors").Str; e != "\n\n" { - return "", fmt.Errorf(cutTooLong(clearNewLineSuffix(e))) + return "", errors.New(cutTooLong(clearNewLineSuffix(e))) } output := content.Get("output").Str From e99b80535a734fe32f3ea9b7ea1d2553b35eac8f Mon Sep 17 00:00:00 2001 From: Kanri Date: Fri, 2 Jul 2021 19:55:51 +0800 Subject: [PATCH 10/79] =?UTF-8?q?=F0=9F=99=88=20=E5=88=A0=E9=99=A4=20.idea?= =?UTF-8?q?=20=E6=96=87=E4=BB=B6=E5=A4=B9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .idea/workspace.xml | 124 -------------------------------------------- 1 file changed, 124 deletions(-) delete mode 100644 .idea/workspace.xml diff --git a/.idea/workspace.xml b/.idea/workspace.xml deleted file mode 100644 index bbc0bff8..00000000 --- a/.idea/workspace.xml +++ /dev/null @@ -1,124 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - true - - \ No newline at end of file From 420f47a57915a94779bed4dcadaaaf7544cdd14a Mon Sep 17 00:00:00 2001 From: Suika99 <290760339@qq.com> Date: Tue, 6 Jul 2021 18:38:45 +0800 Subject: [PATCH 11/79] =?UTF-8?q?=E6=96=B0=E5=A2=9Emc=E6=9C=8D=E5=8A=A1?= =?UTF-8?q?=E5=99=A8=E7=9B=B8=E5=85=B3=E5=8A=9F=E8=83=BD~?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- main.go | 5 ++- plugin_minecraft/info.go | 84 +++++++++++++++++++++++++++++++++++++ plugin_minecraft/manager.go | 75 +++++++++++++++++++++++++++++++++ 3 files changed, 162 insertions(+), 2 deletions(-) create mode 100644 plugin_minecraft/info.go create mode 100644 plugin_minecraft/manager.go diff --git a/main.go b/main.go index ed135ea4..8dce86b0 100644 --- a/main.go +++ b/main.go @@ -18,8 +18,9 @@ import ( // 娱乐类 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_ai_false" // 服务器监控 - _ "github.com/FloatTech/ZeroBot-Plugin/plugin_music" // 点歌 - _ "github.com/FloatTech/ZeroBot-Plugin/plugin_shindan" // 测定 + _ "github.com/FloatTech/ZeroBot-Plugin/plugin_minecraft" + _ "github.com/FloatTech/ZeroBot-Plugin/plugin_music" // 点歌 + _ "github.com/FloatTech/ZeroBot-Plugin/plugin_shindan" // 测定 // b站相关 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_bilibili" // 查询b站用户信息 diff --git a/plugin_minecraft/info.go b/plugin_minecraft/info.go new file mode 100644 index 00000000..28b575f5 --- /dev/null +++ b/plugin_minecraft/info.go @@ -0,0 +1,84 @@ +package plugin_minecraft + +import ( + "encoding/json" + "fmt" + zero "github.com/wdvxdr1123/ZeroBot" + "github.com/wdvxdr1123/ZeroBot/message" + "net/http" + "strings" +) + +type resultjson struct { + IP string `json:"ip"` + Port int `json:"port"` + Debug struct { + Ping bool `json:"ping"` + Query bool `json:"query"` + Srv bool `json:"srv"` + Querymismatch bool `json:"querymismatch"` + Ipinsrv bool `json:"ipinsrv"` + Cnameinsrv bool `json:"cnameinsrv"` + Animatedmotd bool `json:"animatedmotd"` + Cachetime int `json:"cachetime"` + Apiversion int `json:"apiversion"` + } `json:"debug"` + Motd struct { + Raw []string `json:"raw"` + Clean []string `json:"clean"` + HTML []string `json:"html"` + } `json:"motd"` + Players struct { + Online int `json:"online"` + Max int `json:"max"` + List []string `json:"list"` + } `json:"players"` +} + +func init() { + zero.OnRegex(`^/list (.*)$`). + Handle(func(ctx *zero.Ctx) { + // 支持多个服务器 + switch ctx.State["regex_matched"].([]string)[1] { + case "ftbi": // 这里对应触发指令里的服务器名称 + ftbijson := infoapi("115.28.186.22:25710") //这里填对应mc服务器的登录地址 + var str = ftbijson.Players.List + cs := strings.Join(str, "\n") + ctx.SendChain(message.Text( + "服务器名字: ", ftbijson.Motd.Raw[0], "\n", + "在线人数: ", ftbijson.Players.Online, "/", ftbijson.Players.Max, "\n", + "以下为玩家名字: ", "\n", cs, + )) + case "ges": // 这里对应触发指令里的服务器名称 + gesjson := infoapi("115.28.186.22:25701") //这里填对应mc服务器的登录地址 + var str = gesjson.Players.List + cs := strings.Join(str, "\n") + ctx.SendChain(message.Text( + "服务器名字: ", gesjson.Motd.Raw[0], "\n", + "在线人数: ", gesjson.Players.Online, "/", gesjson.Players.Max, "\n", + "以下为玩家名字: ", "\n", cs, + )) + } + }) +} + +// 开放api请求调用 +func infoapi(addr string) *resultjson { + url := "https://api.mcsrvstat.us/2/" + addr + method := "GET" + client := &http.Client{} + req, err := http.NewRequest(method, url, nil) + if err != nil { + fmt.Println(err) + } + res, err := client.Do(req) + if err != nil { + fmt.Println(err) + } + defer res.Body.Close() + result := &resultjson{} + if err := json.NewDecoder(res.Body).Decode(result); err != nil { + panic(err) + } + return result +} diff --git a/plugin_minecraft/manager.go b/plugin_minecraft/manager.go new file mode 100644 index 00000000..311701d6 --- /dev/null +++ b/plugin_minecraft/manager.go @@ -0,0 +1,75 @@ +package plugin_minecraft + +import ( + "fmt" + zero "github.com/wdvxdr1123/ZeroBot" + "github.com/wdvxdr1123/ZeroBot/message" + "io/ioutil" + "net/http" +) + +// 此功能实现依赖MCSManager项目对服务器的管理api,mc服务器如果没有在该管理平台部署此功能无效 +// 项目地址: https://github.com/Suwings/MCSManager +// 项目的api文档: https://github.com/Suwings/MCSManager/wiki/API-Documentation + +func init() { + zero.OnRegex(`^/start (.*)$`). + Handle(func(ctx *zero.Ctx) { + name := ctx.State["regex_matched"].([]string)[1] + ctx.SendChain(message.Text("开启服务器: ", name, ".....")) + result := start(name) + ctx.Send(result) + }) +} + +func init() { + zero.OnRegex(`^/stop (.*)$`). + Handle(func(ctx *zero.Ctx) { + name := ctx.State["regex_matched"].([]string)[1] + ctx.SendChain(message.Text("关闭服务器: ", name, ".....")) + result := stop(name) + ctx.Send(result) + }) +} + +//开启服务器的api请求 +func start(name string) string { + url := fmt.Sprintf("http://your.addr:23333/api/start_server/%s/?apikey=apikey", name) + client := &http.Client{} + req, err := http.NewRequest("GET", url, nil) + if err != nil { + fmt.Println(err) + } + res, err := client.Do(req) + if err != nil { + fmt.Println(err) + } + defer res.Body.Close() + + body, err := ioutil.ReadAll(res.Body) + if err != nil { + fmt.Println(err) + } + return string(body) +} + +//关闭服务器的api请求 +func stop(name string) string { + url := fmt.Sprintf("http://your.addr:23333/api/stop_server/%s/?apikey=apikey", name) + client := &http.Client{} + req, err := http.NewRequest("GET", url, nil) + if err != nil { + fmt.Println(err) + } + res, err := client.Do(req) + if err != nil { + fmt.Println(err) + } + defer res.Body.Close() + + body, err := ioutil.ReadAll(res.Body) + if err != nil { + fmt.Println(err) + } + return string(body) +} From bb58647b3ef72469d4c5ed0a45cea9d510c1f8c0 Mon Sep 17 00:00:00 2001 From: Kanri Date: Wed, 14 Jul 2021 14:10:30 +0800 Subject: [PATCH 12/79] =?UTF-8?q?=E2=9C=8F=EF=B8=8F=20=E4=BF=AE=E5=A4=8D?= =?UTF-8?q?=E6=88=B3=E5=88=AB=E5=AD=97?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_setutime/setu_geter.go | 2 +- plugin_shindan/shindan.go | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/plugin_setutime/setu_geter.go b/plugin_setutime/setu_geter.go index a2e00cf8..a0b58eb1 100644 --- a/plugin_setutime/setu_geter.go +++ b/plugin_setutime/setu_geter.go @@ -59,7 +59,7 @@ func init() { // 插件主体 zero.OnRegex(`^来份(.*)$`, FirstValueInList(POOL.List)).SetBlock(true).SetPriority(20). Handle(func(ctx *zero.Ctx) { if !limit.Load(ctx.Event.UserID).Acquire() { - ctx.SendChain(message.Text("少女祈祷中......")) + ctx.SendChain(message.Text("请稍后重试0x0...")) return } var type_ = ctx.State["regex_matched"].([]string)[1] diff --git a/plugin_shindan/shindan.go b/plugin_shindan/shindan.go index 3107f9bb..501ca140 100644 --- a/plugin_shindan/shindan.go +++ b/plugin_shindan/shindan.go @@ -28,7 +28,7 @@ func init() { // shindanmaker 处理函数 var handle = func(ctx *zero.Ctx) { if !limit.Load(ctx.Event.UserID).Acquire() { - ctx.Send("请稍后重试0x0...") + ctx.SendChain(message.Text("请稍后重试0x0...")) return } // 获取名字 From 3aee9e355ef7429866bfecb85f81111edf2cfcd9 Mon Sep 17 00:00:00 2001 From: Kanri Date: Wed, 14 Jul 2021 14:10:48 +0800 Subject: [PATCH 13/79] =?UTF-8?q?=E2=9C=A8=20=E5=A2=9E=E5=8A=A0=E8=B4=A1?= =?UTF-8?q?=E7=8C=AE=E8=80=85?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- main.go | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/main.go b/main.go index 8dce86b0..75653509 100644 --- a/main.go +++ b/main.go @@ -44,8 +44,8 @@ import ( var content = []string{ "* OneBot + ZeroBot + Golang ", - "* Version 1.0.4 - 2021-07-02 19:14:58.581489207 +0800 CST", - "* Copyright © 2020 - 2021 Kanri, DawnNights, Fumiama ", + "* Version 1.0.4 - 2021-07-14 14:09:58.581489207 +0800 CST", + "* Copyright © 2020 - 2021 Kanri, DawnNights, Fumiama, Suika", "* Project: https://github.com/FloatTech/ZeroBot-Plugin", } From a439ffcc95ca6536eefb067b3af3921f8d92e167 Mon Sep 17 00:00:00 2001 From: Kanri Date: Wed, 14 Jul 2021 14:12:19 +0800 Subject: [PATCH 14/79] =?UTF-8?q?=E2=AC=86=EF=B8=8F=20=E6=9B=B4=E6=96=B0?= =?UTF-8?q?=E4=BE=9D=E8=B5=96=20=E4=BF=AE=E5=A4=8D=20shindan?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- go.mod | 3 ++- go.sum | 4 ++++ 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/go.mod b/go.mod index 51b0b158..bebca4b1 100644 --- a/go.mod +++ b/go.mod @@ -3,7 +3,7 @@ module github.com/FloatTech/ZeroBot-Plugin go 1.16 require ( - github.com/FloatTech/AnimeAPI v0.0.0-20210619112022-a8fdd4fefc07 + github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd github.com/FloatTech/ZeroBot-ACGImage v1.1.2 github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.2 github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46 // indirect @@ -13,6 +13,7 @@ require ( github.com/sirupsen/logrus v1.8.1 github.com/t-tomalak/logrus-easy-formatter v0.0.0-20190827215021-c074f06c5816 github.com/tidwall/gjson v1.8.1 + github.com/tidwall/pretty v1.2.0 // indirect github.com/tklauser/go-sysconf v0.3.6 // indirect github.com/wdvxdr1123/ZeroBot v1.2.1 modernc.org/sqlite v1.11.1 diff --git a/go.sum b/go.sum index ebd0600a..ae763b94 100644 --- a/go.sum +++ b/go.sum @@ -1,5 +1,7 @@ github.com/FloatTech/AnimeAPI v0.0.0-20210619112022-a8fdd4fefc07 h1:7fBPLLoZysaa9PI9ApgzyVMrMLMWBam273YgKwy7Ddg= github.com/FloatTech/AnimeAPI v0.0.0-20210619112022-a8fdd4fefc07/go.mod h1:GYrQD70HvBzry1XiZ1tHFNOsOqRkR+ao4XGYZqV4I9c= +github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd h1:rvV66DIEqNJMEKwYXDJvw6kpJuGg+Pz/BooewuTBjXs= +github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd/go.mod h1:GYrQD70HvBzry1XiZ1tHFNOsOqRkR+ao4XGYZqV4I9c= github.com/FloatTech/ZeroBot-ACGImage v1.1.2 h1:Q+FwOb1vCCYG2B7hPU0uBMzWwB85eVlC0pWRJZ+rBCQ= github.com/FloatTech/ZeroBot-ACGImage v1.1.2/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.2 h1:I7RSCsJVT6elehdaSiWB4n96y06fQxMsvAG494S5Od0= @@ -76,6 +78,8 @@ github.com/tidwall/match v1.0.3 h1:FQUVvBImDutD8wJLN6c5eMzWtjgONK9MwIBCOrUJKeE= github.com/tidwall/match v1.0.3/go.mod h1:eRSPERbgtNPcGhD8UCthc6PmLEQXEWd3PRB5JTxsfmM= github.com/tidwall/pretty v1.1.0 h1:K3hMW5epkdAVwibsQEfR/7Zj0Qgt4DxtNumTq/VloO8= github.com/tidwall/pretty v1.1.0/go.mod h1:XNkn88O1ChpSDQmQeStsy+sBenx6DDtFZJxhVysOjyk= +github.com/tidwall/pretty v1.2.0 h1:RWIZEg2iJ8/g6fDDYzMpobmaoGh5OLl4AXtGUGPcqCs= +github.com/tidwall/pretty v1.2.0/go.mod h1:ITEVvHYasfjBbM0u2Pg8T2nJnzm8xPwvNhhsoaGGjNU= github.com/tklauser/go-sysconf v0.3.6 h1:oc1sJWvKkmvIxhDHeKWvZS4f6AW+YcoguSfRF2/Hmo4= github.com/tklauser/go-sysconf v0.3.6/go.mod h1:MkWzOF4RMCshBAMXuhXJs64Rte09mITnppBXY/rYEFI= github.com/tklauser/numcpus v0.2.2 h1:oyhllyrScuYI6g+h/zUvNXNp1wy7x8qQy3t/piefldA= From aa9fa3af32fee2c7e793d3cbf4ba0a7367e713ff Mon Sep 17 00:00:00 2001 From: fumiama Date: Sun, 18 Jul 2021 20:29:55 +0800 Subject: [PATCH 15/79] =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E7=BE=A4=E7=AE=A1?= =?UTF-8?q?=E5=AE=9A=E6=97=B6=E6=8F=90=E9=86=92=E6=97=A0=E6=B3=95=E5=8F=96?= =?UTF-8?q?=E6=B6=88?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- go.mod | 4 ++- go.sum | 27 ++++++++++------- plugin_manager/manager.go | 62 +++++++++++++++------------------------ 3 files changed, 44 insertions(+), 49 deletions(-) diff --git a/go.mod b/go.mod index bebca4b1..b259408e 100644 --- a/go.mod +++ b/go.mod @@ -5,7 +5,7 @@ go 1.16 require ( github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd github.com/FloatTech/ZeroBot-ACGImage v1.1.2 - github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.2 + github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4 github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46 // indirect github.com/go-ole/go-ole v1.2.5 // indirect github.com/robfig/cron v1.2.0 @@ -16,5 +16,7 @@ require ( github.com/tidwall/pretty v1.2.0 // indirect github.com/tklauser/go-sysconf v0.3.6 // indirect github.com/wdvxdr1123/ZeroBot v1.2.1 + golang.org/x/text v0.3.6 // indirect + golang.org/x/tools v0.1.3-0.20210608163600-9ed039809d4c // indirect modernc.org/sqlite v1.11.1 ) diff --git a/go.sum b/go.sum index ae763b94..120729c3 100644 --- a/go.sum +++ b/go.sum @@ -1,11 +1,9 @@ -github.com/FloatTech/AnimeAPI v0.0.0-20210619112022-a8fdd4fefc07 h1:7fBPLLoZysaa9PI9ApgzyVMrMLMWBam273YgKwy7Ddg= -github.com/FloatTech/AnimeAPI v0.0.0-20210619112022-a8fdd4fefc07/go.mod h1:GYrQD70HvBzry1XiZ1tHFNOsOqRkR+ao4XGYZqV4I9c= github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd h1:rvV66DIEqNJMEKwYXDJvw6kpJuGg+Pz/BooewuTBjXs= github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd/go.mod h1:GYrQD70HvBzry1XiZ1tHFNOsOqRkR+ao4XGYZqV4I9c= github.com/FloatTech/ZeroBot-ACGImage v1.1.2 h1:Q+FwOb1vCCYG2B7hPU0uBMzWwB85eVlC0pWRJZ+rBCQ= github.com/FloatTech/ZeroBot-ACGImage v1.1.2/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= -github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.2 h1:I7RSCsJVT6elehdaSiWB4n96y06fQxMsvAG494S5Od0= -github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.2/go.mod h1:femu/wVuqVSN/rg209qksMx8/2OKUF8l1PZCNg4RwVA= +github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4 h1:BMrSHJO1lWKTKU1DCK+XEpTaK38FMlBEIywFLIiatu8= +github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4/go.mod h1:femu/wVuqVSN/rg209qksMx8/2OKUF8l1PZCNg4RwVA= github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46 h1:5sXbqlSomvdjlRbWyNqkPsJ3Fg+tQZCbgeX1VGljbQY= github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46/go.mod h1:3eOhrUMpNV+6aFIbp5/iudMxNCF27Vw2OZgy4xEx0Fg= github.com/antchfx/htmlquery v1.2.3 h1:sP3NFDneHx2stfNXCKbhHFo8XgNjCACnU/4AO5gWz6M= @@ -76,7 +74,6 @@ github.com/tidwall/gjson v1.8.1 h1:8j5EE9Hrh3l9Od1OIEDAb7IpezNA20UdRngNAj5N0WU= github.com/tidwall/gjson v1.8.1/go.mod h1:5/xDoumyyDNerp2U36lyolv46b3uF/9Bu6OfyQ9GImk= github.com/tidwall/match v1.0.3 h1:FQUVvBImDutD8wJLN6c5eMzWtjgONK9MwIBCOrUJKeE= github.com/tidwall/match v1.0.3/go.mod h1:eRSPERbgtNPcGhD8UCthc6PmLEQXEWd3PRB5JTxsfmM= -github.com/tidwall/pretty v1.1.0 h1:K3hMW5epkdAVwibsQEfR/7Zj0Qgt4DxtNumTq/VloO8= github.com/tidwall/pretty v1.1.0/go.mod h1:XNkn88O1ChpSDQmQeStsy+sBenx6DDtFZJxhVysOjyk= github.com/tidwall/pretty v1.2.0 h1:RWIZEg2iJ8/g6fDDYzMpobmaoGh5OLl4AXtGUGPcqCs= github.com/tidwall/pretty v1.2.0/go.mod h1:ITEVvHYasfjBbM0u2Pg8T2nJnzm8xPwvNhhsoaGGjNU= @@ -87,20 +84,24 @@ github.com/tklauser/numcpus v0.2.2/go.mod h1:x3qojaO3uyYt0i56EW/VUYs7uBvdl2fkfZF github.com/wdvxdr1123/ZeroBot v1.2.1 h1:ougeP+VOAGlQWCAUSB7fjA5trzEvPepU7pujsoYTCq8= github.com/wdvxdr1123/ZeroBot v1.2.1/go.mod h1:83nHtG8V5TAxPwH/LCDxLpZk4khIgs29dkr5TBWf7fc= github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= +github.com/yuin/goldmark v1.3.5/go.mod h1:mwnBkeHKe2W/ZEtQ+71ViKU8L12m81fl3OWwC1Zlc8k= golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= -golang.org/x/mod v0.3.0 h1:RM4zey1++hCTbCVQfnWeKs9/IEsaBLA8vTkd0WVtmH4= golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= +golang.org/x/mod v0.4.2 h1:Gz96sIWK3OalVv/I/qNygP42zyoKp3xptRVCWRFEBvo= +golang.org/x/mod v0.4.2/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/net v0.0.0-20180906233101-161cd47e91fd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20200421231249-e086a090c8fd/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= -golang.org/x/net v0.0.0-20201021035429-f5854403a974 h1:IX6qOQeG5uLjB/hjjwjedwfjND0hgjPMMyO1RoIXQNI= golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= +golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4 h1:4nGaVu0QrbjT/AK2PRLuQfQuh6DJve+pELhqTdAj3x0= +golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4/go.mod h1:p54w0d4576C0XHj96bSt6lcn1PtDYWL6XObtHCRCNQM= golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= @@ -110,17 +111,23 @@ golang.org/x/sys v0.0.0-20191026070338-33540a1f6037/go.mod h1:h1NjWce9XRLGQEsW7w golang.org/x/sys v0.0.0-20200116001909-b77594299b42/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200323222414-85ca7c5b95cd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20201126233918-771906719818/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210124154548-22da62e12c0c/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20210316164454-77fc1eacc6aa h1:ZYxPR6aca/uhfRJyaOAtflSHjJYiktO7QnJC5ut7iY4= golang.org/x/sys v0.0.0-20210316164454-77fc1eacc6aa/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210330210617-4fbd30eecc44/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210510120138-977fb7262007 h1:gG67DSER+11cZvqIMb8S8bt0vZtiN6xWYARwirrOSfE= +golang.org/x/sys v0.0.0-20210510120138-977fb7262007/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= -golang.org/x/text v0.3.3 h1:cokOdA+Jmi5PJGXLlLllQSgYigAEfHXJAERHVMaCc2k= golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= +golang.org/x/text v0.3.6 h1:aRYxNxv6iGQlyVaZmk6ZgYEDa+Jg18DxebPSrd6bg1M= +golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= -golang.org/x/tools v0.0.0-20201124115921-2c860bdd6e78 h1:M8tBwCtWD/cZV9DZpFYRUgaymAYAr+aIUTWzDaM3uPs= golang.org/x/tools v0.0.0-20201124115921-2c860bdd6e78/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= +golang.org/x/tools v0.1.3-0.20210608163600-9ed039809d4c h1:Pv9gNyJFYVdpUAVZYJ1BDSU4eGgXQ+0f3DIGAdolO5s= +golang.org/x/tools v0.1.3-0.20210608163600-9ed039809d4c/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= diff --git a/plugin_manager/manager.go b/plugin_manager/manager.go index 18453e70..f61fe803 100644 --- a/plugin_manager/manager.go +++ b/plugin_manager/manager.go @@ -34,7 +34,6 @@ func init() { // 插件主体 "- 群聊转发 1234 XXX", "\n", "- 私聊转发 0000 XXX", )) - return }) // 升为管理 zero.OnRegex(`^升为管理.*?(\d+)`, zero.OnlyGroup, zero.SuperUserPermission).SetBlock(true).SetPriority(40). @@ -50,7 +49,6 @@ func init() { // 插件主体 false, ).Get("nickname").Str ctx.SendChain(message.Text(nickname + " 升为了管理~")) - return }) // 取消管理 zero.OnRegex(`^取消管理.*?(\d+)`, zero.OnlyGroup, zero.SuperUserPermission).SetBlock(true).SetPriority(40). @@ -66,7 +64,6 @@ func init() { // 插件主体 false, ).Get("nickname").Str ctx.SendChain(message.Text("残念~ " + nickname + " 暂时失去了管理员的资格")) - return }) // 踢出群聊 zero.OnRegex(`^踢出群聊.*?(\d+)`, zero.OnlyGroup, zero.AdminPermission).SetBlock(true).SetPriority(40). @@ -82,7 +79,6 @@ func init() { // 插件主体 false, ).Get("nickname").Str ctx.SendChain(message.Text("残念~ " + nickname + " 被放逐")) - return }) // 退出群聊 zero.OnRegex(`^退出群聊.*?(\d+)`, zero.OnlyGroup, zero.AdminPermission).SetBlock(true).SetPriority(40). @@ -91,7 +87,6 @@ func init() { // 插件主体 strToInt(ctx.State["regex_matched"].([]string)[1]), // 要退出的群的群号 true, ) - return }) // 开启全体禁言 zero.OnRegex(`^开启全员禁言$`, zero.OnlyGroup, zero.AdminPermission).SetBlock(true).SetPriority(40). @@ -101,7 +96,6 @@ func init() { // 插件主体 true, ) ctx.SendChain(message.Text("全员自闭开始~")) - return }) // 解除全员禁言 zero.OnRegex(`^解除全员禁言$`, zero.OnlyGroup, zero.AdminPermission).SetBlock(true).SetPriority(40). @@ -111,7 +105,6 @@ func init() { // 插件主体 false, ) ctx.SendChain(message.Text("全员自闭结束~")) - return }) // 禁言 zero.OnRegex(`^禁言.*?(\d+).*?\s(\d+)(.*)`, zero.OnlyGroup, zero.AdminPermission).SetBlock(true).SetPriority(40). @@ -136,7 +129,6 @@ func init() { // 插件主体 duration*60, // 要禁言的时间(分钟) ) ctx.SendChain(message.Text("小黑屋收留成功~")) - return }) // 解除禁言 zero.OnRegex(`^解除禁言.*?(\d+)`, zero.OnlyGroup, zero.AdminPermission).SetBlock(true).SetPriority(40). @@ -147,7 +139,6 @@ func init() { // 插件主体 0, ) ctx.SendChain(message.Text("小黑屋释放成功~")) - return }) // 自闭禁言 zero.OnRegex(`^我要自闭.*?(\d+)(.*)`, zero.OnlyGroup).SetBlock(true).SetPriority(40). @@ -172,7 +163,6 @@ func init() { // 插件主体 duration*60, // 要自闭的时间(分钟) ) ctx.SendChain(message.Text("那我就不手下留情了~")) - return }) // 修改名片 zero.OnRegex(`^修改名片.*?(\d+).*?\s(.*)`, zero.OnlyGroup, zero.AdminPermission).SetBlock(true).SetPriority(40). @@ -183,7 +173,6 @@ func init() { // 插件主体 ctx.State["regex_matched"].([]string)[2], // 修改成的群名片 ) ctx.SendChain(message.Text("嗯!已经修改了")) - return }) // 修改头衔 zero.OnRegex(`^修改头衔.*?(\d+).*?\s(.*)`, zero.OnlyGroup, zero.AdminPermission).SetBlock(true).SetPriority(40). @@ -194,7 +183,6 @@ func init() { // 插件主体 ctx.State["regex_matched"].([]string)[2], // 修改成的群头衔 ) ctx.SendChain(message.Text("嗯!已经修改了")) - return }) // 申请头衔 zero.OnRegex(`^申请头衔(.*)`, zero.OnlyGroup).SetBlock(true).SetPriority(40). @@ -205,7 +193,6 @@ func init() { // 插件主体 ctx.State["regex_matched"].([]string)[1], // 修改成的群头衔 ) ctx.SendChain(message.Text("嗯!不错的头衔呢~")) - return }) // 群聊转发 zero.OnRegex(`^群聊转发.*?(\d+)\s(.*)`, zero.SuperUserPermission).SetBlock(true).SetPriority(40). @@ -219,7 +206,6 @@ func init() { // 插件主体 content, // 需要发送的信息 ) ctx.SendChain(message.Text("📧 --> " + ctx.State["regex_matched"].([]string)[1])) - return }) // 私聊转发 zero.OnRegex(`^私聊转发.*?(\d+)\s(.*)`, zero.SuperUserPermission).SetBlock(true).SetPriority(40). @@ -233,39 +219,41 @@ func init() { // 插件主体 content, // 需要发送的信息 ) ctx.SendChain(message.Text("📧 --> " + ctx.State["regex_matched"].([]string)[1])) - return }) // 定时提醒 zero.OnRegex(`^在(.{1,2})月(.{1,3}日|每?周.?)的(.{1,3})点(.{1,3})分时(用.+)?提醒大家(.*)`, zero.SuperUserPermission).SetBlock(true).SetPriority(40). Handle(func(ctx *zero.Ctx) { - dateStrs := ctx.State["regex_matched"].([]string) - ts := timer.GetFilledTimeStamp(dateStrs, false) - ts.Grpid = uint64(ctx.Event.GroupID) - if ts.Enable { - go timer.RegisterTimer(ts, true) - ctx.Send("记住了~") - } else { - ctx.Send("参数非法!") + if ctx.Event.GroupID > 0 { + dateStrs := ctx.State["regex_matched"].([]string) + ts := timer.GetFilledTimeStamp(dateStrs, false) + ts.Grpid = uint64(ctx.Event.GroupID) + if ts.Enable { + go timer.RegisterTimer(ts, true) + ctx.Send("记住了~") + } else { + ctx.Send("参数非法!") + } } - return }) // 取消定时 zero.OnRegex(`^取消在(.{1,2})月(.{1,3}日|每?周.?)的(.{1,3})点(.{1,3})分的提醒`, zero.SuperUserPermission).SetBlock(true).SetPriority(40). Handle(func(ctx *zero.Ctx) { - dateStrs := ctx.State["regex_matched"].([]string) - ts := timer.GetFilledTimeStamp(dateStrs, true) - ti := timer.GetTimerInfo(ts) - t, ok := (*timer.Timers)[ti] - if ok { - t.Enable = false - delete(*timer.Timers, ti) //避免重复取消 - _ = timer.SaveTimers() - ctx.Send("取消成功~") - } else { - ctx.Send("没有这个定时器哦~") + if ctx.Event.GroupID > 0 { + dateStrs := ctx.State["regex_matched"].([]string) + ts := timer.GetFilledTimeStamp(dateStrs, true) + ts.Grpid = uint64(ctx.Event.GroupID) + ti := timer.GetTimerInfo(ts) + t, ok := (*timer.Timers)[ti] + if ok { + t.Enable = false + delete(*timer.Timers, ti) //避免重复取消 + _ = timer.SaveTimers() + ctx.Send("取消成功~") + } else { + ctx.Send("没有这个定时器哦~") + } } - return }) // 随机点名 @@ -288,7 +276,6 @@ func init() { // 插件主体 if ctx.Event.NoticeType == "group_increase" { ctx.SendChain(message.Text("欢迎~")) } - return }) // 退群提醒 zero.OnNotice().SetBlock(false).SetPriority(40). @@ -296,7 +283,6 @@ func init() { // 插件主体 if ctx.Event.NoticeType == "group_decrease" { ctx.SendChain(message.Text("有人跑路了~")) } - return }) // 运行 CQ 码 zero.OnRegex(`^run(.*)$`, zero.SuperUserPermission).SetBlock(true).SetPriority(0). From a315afff9ef837a58a887c3990b7223980b795e0 Mon Sep 17 00:00:00 2001 From: fumiama Date: Thu, 29 Jul 2021 22:16:36 +0800 Subject: [PATCH 16/79] =?UTF-8?q?=E5=8D=87=E7=BA=A7mod=E5=88=B0=E6=9C=80?= =?UTF-8?q?=E6=96=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- go.mod | 12 ++++++------ go.sum | 23 +++++++++++++++++++++++ plugin_manager/manager.go | 9 +++++++-- 3 files changed, 36 insertions(+), 8 deletions(-) diff --git a/go.mod b/go.mod index b259408e..e76c4c4a 100644 --- a/go.mod +++ b/go.mod @@ -5,8 +5,8 @@ go 1.16 require ( github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd github.com/FloatTech/ZeroBot-ACGImage v1.1.2 - github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4 - github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46 // indirect + github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.1 + github.com/StackExchange/wmi v1.2.0 // indirect github.com/go-ole/go-ole v1.2.5 // indirect github.com/robfig/cron v1.2.0 github.com/shirou/gopsutil v3.21.6+incompatible @@ -14,9 +14,9 @@ require ( github.com/t-tomalak/logrus-easy-formatter v0.0.0-20190827215021-c074f06c5816 github.com/tidwall/gjson v1.8.1 github.com/tidwall/pretty v1.2.0 // indirect - github.com/tklauser/go-sysconf v0.3.6 // indirect - github.com/wdvxdr1123/ZeroBot v1.2.1 + github.com/tklauser/go-sysconf v0.3.7 // indirect + github.com/wdvxdr1123/ZeroBot v1.2.2 golang.org/x/text v0.3.6 // indirect - golang.org/x/tools v0.1.3-0.20210608163600-9ed039809d4c // indirect - modernc.org/sqlite v1.11.1 + golang.org/x/tools v0.1.5 // indirect + modernc.org/sqlite v1.12.0 ) diff --git a/go.sum b/go.sum index 120729c3..c22143fa 100644 --- a/go.sum +++ b/go.sum @@ -4,8 +4,12 @@ github.com/FloatTech/ZeroBot-ACGImage v1.1.2 h1:Q+FwOb1vCCYG2B7hPU0uBMzWwB85eVlC github.com/FloatTech/ZeroBot-ACGImage v1.1.2/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4 h1:BMrSHJO1lWKTKU1DCK+XEpTaK38FMlBEIywFLIiatu8= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4/go.mod h1:femu/wVuqVSN/rg209qksMx8/2OKUF8l1PZCNg4RwVA= +github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.1 h1:AT/nudxY5murKpEyP+ZZTczknSipeZPP2tId6/2I7Nw= +github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.1/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46 h1:5sXbqlSomvdjlRbWyNqkPsJ3Fg+tQZCbgeX1VGljbQY= github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46/go.mod h1:3eOhrUMpNV+6aFIbp5/iudMxNCF27Vw2OZgy4xEx0Fg= +github.com/StackExchange/wmi v1.2.0 h1:noJEYkMQVlFCEAc+2ma5YyRhlfjcWfZqk5sBRYozdyM= +github.com/StackExchange/wmi v1.2.0/go.mod h1:3eOhrUMpNV+6aFIbp5/iudMxNCF27Vw2OZgy4xEx0Fg= github.com/antchfx/htmlquery v1.2.3 h1:sP3NFDneHx2stfNXCKbhHFo8XgNjCACnU/4AO5gWz6M= github.com/antchfx/htmlquery v1.2.3/go.mod h1:B0ABL+F5irhhMWg54ymEZinzMSi0Kt3I2if0BLYa3V0= github.com/antchfx/xpath v1.1.6 h1:6sVh6hB5T6phw1pFpHRQ+C4bd8sNI+O58flqtg7h0R0= @@ -41,6 +45,7 @@ github.com/mattn/go-isatty v0.0.12 h1:wuysRhFDzyxgEmMf5xjvJ2M9dZoWAXNNr5LSBS7uHX github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Kysco4FUpU= github.com/mattn/go-sqlite3 v1.14.6 h1:dNPt6NO46WmLVt2DLNpwczCmdV5boIZ6g/tlDrlRUbg= github.com/mattn/go-sqlite3 v1.14.6/go.mod h1:NyWgC/yNuGj7Q9rpYnZvas74GogHl5/Z4A/KQRfk6bU= +github.com/mattn/go-sqlite3 v1.14.8/go.mod h1:NyWgC/yNuGj7Q9rpYnZvas74GogHl5/Z4A/KQRfk6bU= github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421 h1:ZqeYNhU3OHLH3mGKHDcjJRFFRrJa6eAM5H+CtDdOsPc= github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0= @@ -79,10 +84,16 @@ github.com/tidwall/pretty v1.2.0 h1:RWIZEg2iJ8/g6fDDYzMpobmaoGh5OLl4AXtGUGPcqCs= github.com/tidwall/pretty v1.2.0/go.mod h1:ITEVvHYasfjBbM0u2Pg8T2nJnzm8xPwvNhhsoaGGjNU= github.com/tklauser/go-sysconf v0.3.6 h1:oc1sJWvKkmvIxhDHeKWvZS4f6AW+YcoguSfRF2/Hmo4= github.com/tklauser/go-sysconf v0.3.6/go.mod h1:MkWzOF4RMCshBAMXuhXJs64Rte09mITnppBXY/rYEFI= +github.com/tklauser/go-sysconf v0.3.7 h1:HT7h4+536gjqeq1ZIJPgOl1rg1XFatQGVZWp7Py53eg= +github.com/tklauser/go-sysconf v0.3.7/go.mod h1:JZIdXh4RmBvZDBZ41ld2bGxRV3n4daiiqA3skYhAoQ4= github.com/tklauser/numcpus v0.2.2 h1:oyhllyrScuYI6g+h/zUvNXNp1wy7x8qQy3t/piefldA= github.com/tklauser/numcpus v0.2.2/go.mod h1:x3qojaO3uyYt0i56EW/VUYs7uBvdl2fkfZFu0T9wgjM= +github.com/tklauser/numcpus v0.2.3 h1:nQ0QYpiritP6ViFhrKYsiv6VVxOpum2Gks5GhnJbS/8= +github.com/tklauser/numcpus v0.2.3/go.mod h1:vpEPS/JC+oZGGQ/My/vJnNsvMDQL6PwOqt8dsCw5j+E= github.com/wdvxdr1123/ZeroBot v1.2.1 h1:ougeP+VOAGlQWCAUSB7fjA5trzEvPepU7pujsoYTCq8= github.com/wdvxdr1123/ZeroBot v1.2.1/go.mod h1:83nHtG8V5TAxPwH/LCDxLpZk4khIgs29dkr5TBWf7fc= +github.com/wdvxdr1123/ZeroBot v1.2.2 h1:BKEy3l80BMrQWpFWaII0AfFMyf9bqrB0TxfWhTdoV58= +github.com/wdvxdr1123/ZeroBot v1.2.2/go.mod h1:83nHtG8V5TAxPwH/LCDxLpZk4khIgs29dkr5TBWf7fc= github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= github.com/yuin/goldmark v1.3.5/go.mod h1:mwnBkeHKe2W/ZEtQ+71ViKU8L12m81fl3OWwC1Zlc8k= golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= @@ -118,6 +129,8 @@ golang.org/x/sys v0.0.0-20210316164454-77fc1eacc6aa/go.mod h1:h1NjWce9XRLGQEsW7w golang.org/x/sys v0.0.0-20210330210617-4fbd30eecc44/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210510120138-977fb7262007 h1:gG67DSER+11cZvqIMb8S8bt0vZtiN6xWYARwirrOSfE= golang.org/x/sys v0.0.0-20210510120138-977fb7262007/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c h1:F1jZWGFhYfh0Ci55sIpILtKKK8p3i2/krTr0H1rg74I= +golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= @@ -128,6 +141,8 @@ golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtn golang.org/x/tools v0.0.0-20201124115921-2c860bdd6e78/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= golang.org/x/tools v0.1.3-0.20210608163600-9ed039809d4c h1:Pv9gNyJFYVdpUAVZYJ1BDSU4eGgXQ+0f3DIGAdolO5s= golang.org/x/tools v0.1.3-0.20210608163600-9ed039809d4c/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= +golang.org/x/tools v0.1.5 h1:ouewzE6p+/VEB31YYnTbEJdi8pFqKp4P4n85vwo3DHA= +golang.org/x/tools v0.1.5/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= @@ -146,8 +161,12 @@ lukechampine.com/uint128 v1.1.1 h1:pnxCASz787iMf+02ssImqk6OLt+Z5QHMoZyUXR4z6JU= lukechampine.com/uint128 v1.1.1/go.mod h1:c4eWIwlEGaxC/+H1VguhU4PHXNWDCDMUlWdIWl2j1gk= modernc.org/cc/v3 v3.33.6 h1:r63dgSzVzRxUpAJFPQWHy1QeZeY1ydNENUDaBx1GqYc= modernc.org/cc/v3 v3.33.6/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g= +modernc.org/cc/v3 v3.33.7 h1:Rvxffgx6LHSpGS6IO8bffSYN1wpPsWHEWY9CV95vpro= +modernc.org/cc/v3 v3.33.7/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g= modernc.org/ccgo/v3 v3.9.5 h1:dEuUSf8WN51rDkprFuAqjfchKEzN0WttP/Py3enBwjk= modernc.org/ccgo/v3 v3.9.5/go.mod h1:umuo2EP2oDSBnD3ckjaVUXMrmeAw8C8OSICVa0iFf60= +modernc.org/ccgo/v3 v3.9.6 h1:rCjLgu6iRxK2bqq8A0CCOnDP+tdA81LfbBUlM1L6ZIY= +modernc.org/ccgo/v3 v3.9.6/go.mod h1:KGOi0NhaT6CO19xeSXcpXBl0OkoD6T1U4dPd633G9Sg= modernc.org/httpfs v1.0.6 h1:AAgIpFZRXuYnkjftxTAZwMIiwEqAfk8aVB2/oA6nAeM= modernc.org/httpfs v1.0.6/go.mod h1:7dosgurJGp0sPaRanU53W4xZYKh14wfzX420oZADeHM= modernc.org/libc v1.7.13-0.20210308123627-12f642a52bb8/go.mod h1:U1eq8YWr/Kc1RWCMFUWEdkTg8OTcfLw2kY8EDwl039w= @@ -158,12 +177,16 @@ modernc.org/mathutil v1.1.1/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6 modernc.org/mathutil v1.2.2/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6E= modernc.org/mathutil v1.4.0 h1:GCjoRaBew8ECCKINQA2nYjzvufFW9YiEuuB+rQ9bn2E= modernc.org/mathutil v1.4.0/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6E= +modernc.org/mathutil v1.4.1 h1:ij3fYGe8zBF4Vu+g0oT7mB06r8sqGWKuJu1yXeR4by8= +modernc.org/mathutil v1.4.1/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6E= modernc.org/memory v1.0.4 h1:utMBrFcpnQDdNsmM6asmyH/FM9TqLPS7XF7otpJmrwM= modernc.org/memory v1.0.4/go.mod h1:nV2OApxradM3/OVbs2/0OsP6nPfakXpi50C7dcoHXlc= modernc.org/opt v0.1.1 h1:/0RX92k9vwVeDXj+Xn23DKp2VJubL7k8qNffND6qn3A= modernc.org/opt v0.1.1/go.mod h1:WdSiB5evDcignE70guQKxYUl14mgWtbClRi5wmkkTX0= modernc.org/sqlite v1.11.1 h1:SSLaty1rFr9JhVH/Usm2BxzlzaCtf0GhTJ/MJ32GU3Y= modernc.org/sqlite v1.11.1/go.mod h1:+mhs/P1ONd+6G7hcAs6irwDi/bjTQ7nLW6LHRBsEa3A= +modernc.org/sqlite v1.12.0 h1:AMAOgk4CkblRJc6YLKSYtz3pZ6DW5wjQ1uYH/rN7/Kk= +modernc.org/sqlite v1.12.0/go.mod h1:ppqJ4cQ+R09YLzl9haEL9AYgj6wX8FcfwDTOI0nYykU= modernc.org/strutil v1.1.1 h1:xv+J1BXY3Opl2ALrBwyfEikFAj8pmqcpnfmuwUwcozs= modernc.org/strutil v1.1.1/go.mod h1:DE+MQQ/hjKBZS2zNInV5hhcipt5rLPWkmpbGeW5mmdw= modernc.org/tcl v1.5.5 h1:N03RwthgTR/l/eQvz3UjfYnvVVj1G2sZqzFGfoD4HE4= diff --git a/plugin_manager/manager.go b/plugin_manager/manager.go index f61fe803..b7f3d931 100644 --- a/plugin_manager/manager.go +++ b/plugin_manager/manager.go @@ -220,7 +220,6 @@ func init() { // 插件主体 ) ctx.SendChain(message.Text("📧 --> " + ctx.State["regex_matched"].([]string)[1])) }) - // 定时提醒 zero.OnRegex(`^在(.{1,2})月(.{1,3}日|每?周.?)的(.{1,3})点(.{1,3})分时(用.+)?提醒大家(.*)`, zero.SuperUserPermission).SetBlock(true).SetPriority(40). Handle(func(ctx *zero.Ctx) { @@ -255,7 +254,13 @@ func init() { // 插件主体 } } }) - + //列出本群所有定时 + zero.OnFullMatch("列出所有提醒", zero.SuperUserPermission).SetBlock(true).SetPriority(40). + Handle(func(ctx *zero.Ctx) { + if ctx.Event.GroupID > 0 { + ctx.Send("") + } + }) // 随机点名 zero.OnFullMatchGroup([]string{"翻牌"}).SetBlock(true).SetPriority(40). Handle(func(ctx *zero.Ctx) { From 76c29042c8e68badeaf288644f3c0cd5d1e80a61 Mon Sep 17 00:00:00 2001 From: fumiama Date: Thu, 29 Jul 2021 22:17:28 +0800 Subject: [PATCH 17/79] =?UTF-8?q?=E5=A2=9E=E5=8A=A0=E5=88=97=E5=87=BA?= =?UTF-8?q?=E6=89=80=E6=9C=89=E6=8F=90=E9=86=92?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_manager/manager.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugin_manager/manager.go b/plugin_manager/manager.go index b7f3d931..daf4bf02 100644 --- a/plugin_manager/manager.go +++ b/plugin_manager/manager.go @@ -258,7 +258,7 @@ func init() { // 插件主体 zero.OnFullMatch("列出所有提醒", zero.SuperUserPermission).SetBlock(true).SetPriority(40). Handle(func(ctx *zero.Ctx) { if ctx.Event.GroupID > 0 { - ctx.Send("") + ctx.Send(timer.ListTimers(uint64(ctx.Event.GroupID))) } }) // 随机点名 From fa1bde2ed16a6d8374779b42e0991ec456271d41 Mon Sep 17 00:00:00 2001 From: fumiama Date: Thu, 29 Jul 2021 22:26:39 +0800 Subject: [PATCH 18/79] =?UTF-8?q?=E4=BF=AE=E6=AD=A3=E6=A0=BC=E5=BC=8F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_manager/manager.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugin_manager/manager.go b/plugin_manager/manager.go index daf4bf02..a4367d55 100644 --- a/plugin_manager/manager.go +++ b/plugin_manager/manager.go @@ -258,7 +258,7 @@ func init() { // 插件主体 zero.OnFullMatch("列出所有提醒", zero.SuperUserPermission).SetBlock(true).SetPriority(40). Handle(func(ctx *zero.Ctx) { if ctx.Event.GroupID > 0 { - ctx.Send(timer.ListTimers(uint64(ctx.Event.GroupID))) + ctx.Send(fmt.Sprint(timer.ListTimers(uint64(ctx.Event.GroupID)))) } }) // 随机点名 From a966dfac45f2c589ee9735c460da6a6acba5cab6 Mon Sep 17 00:00:00 2001 From: fumiama Date: Thu, 29 Jul 2021 22:40:32 +0800 Subject: [PATCH 19/79] =?UTF-8?q?=E5=88=97=E5=87=BA=E6=8F=90=E9=86=92?= =?UTF-8?q?=E4=B8=8D=E6=98=BE=E7=A4=BA=E7=BE=A4=E5=8F=B7?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- go.mod | 2 +- go.sum | 4 ++++ 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/go.mod b/go.mod index e76c4c4a..3fc04d28 100644 --- a/go.mod +++ b/go.mod @@ -5,7 +5,7 @@ go 1.16 require ( github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd github.com/FloatTech/ZeroBot-ACGImage v1.1.2 - github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.1 + github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.3 github.com/StackExchange/wmi v1.2.0 // indirect github.com/go-ole/go-ole v1.2.5 // indirect github.com/robfig/cron v1.2.0 diff --git a/go.sum b/go.sum index c22143fa..1ab5bc82 100644 --- a/go.sum +++ b/go.sum @@ -6,6 +6,10 @@ github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4 h1:BMrSHJO1lWKTKU1DCK+XEpTaK38F github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4/go.mod h1:femu/wVuqVSN/rg209qksMx8/2OKUF8l1PZCNg4RwVA= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.1 h1:AT/nudxY5murKpEyP+ZZTczknSipeZPP2tId6/2I7Nw= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.1/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= +github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.2 h1:mVkuGVtznDH1n0l00TJesmA5K2NZ+98OaXcqyPh6TVM= +github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.2/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= +github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.3 h1:NXk18XCfy4cCSMXru/NHfCdf26o3fBWOTuEvxFcweeg= +github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.3/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46 h1:5sXbqlSomvdjlRbWyNqkPsJ3Fg+tQZCbgeX1VGljbQY= github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46/go.mod h1:3eOhrUMpNV+6aFIbp5/iudMxNCF27Vw2OZgy4xEx0Fg= github.com/StackExchange/wmi v1.2.0 h1:noJEYkMQVlFCEAc+2ma5YyRhlfjcWfZqk5sBRYozdyM= From 36a7dce1e9e343a0576efb7f5c44522e85b14251 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=BA=90=E6=96=87=E9=9B=A8?= <41315874+fumiama@users.noreply.github.com> Date: Thu, 29 Jul 2021 22:46:22 +0800 Subject: [PATCH 20/79] =?UTF-8?q?=E2=9C=A8=20=E5=AE=8C=E5=96=84=E8=AF=B4?= =?UTF-8?q?=E6=98=8E=E5=B9=B6=E5=A2=9E=E5=8A=A0=E6=96=B0=E6=9D=A1=E7=9B=AE?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 46a27e34..b2d02b7e 100644 --- a/README.md +++ b/README.md @@ -47,6 +47,7 @@ - [x] 在[月份]月[每周or周几]的[小时]点[分钟]分时(用[url])提醒大家[消息] - [x] 取消在[月份]月[日期]日的[小时]点[分钟]分的提醒 - [x] 取消在[月份]月[每周or周几]的[小时]点[分钟]分的提醒 + - [x] 列出所有提醒 - [x] 翻牌 - [ ] 同意入群请求 - [ ] 同意好友请求 @@ -80,11 +81,11 @@ - [x] 以图搜图|搜索图片|以图识图[图片] - [x] 搜图[P站图片ID] - 随机图片与点评 `github.com/FloatTech/ZeroBot-Plugin/plugin_rand_image` - - [x] 随机图片 + - [x] 随机图片(也有概率出r18,请务必小心) - [x] 直接随机(无r18检测,后果自负) - [x] 设置随机图片网址[url] - [x] 太涩了(撤回最近发的图) - - [x] 评价图片:发送一张图片进行评分 + - [x] 评价图片:发送一张图片让bot评分 - bilibili `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_bilibili"` - [x] >bili info [名字] - 嘉然 `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_diana"` From d78b9d762fba9323426ccd0b0d60757172c3f93c Mon Sep 17 00:00:00 2001 From: fumiama Date: Sat, 31 Jul 2021 19:54:27 +0800 Subject: [PATCH 21/79] =?UTF-8?q?=E6=9B=B4=E6=96=B0ACGImage?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- go.mod | 4 ++-- go.sum | 4 ++++ 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/go.mod b/go.mod index 3fc04d28..9a901c6e 100644 --- a/go.mod +++ b/go.mod @@ -4,9 +4,9 @@ go 1.16 require ( github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd - github.com/FloatTech/ZeroBot-ACGImage v1.1.2 + github.com/FloatTech/ZeroBot-ACGImage v1.2.1 github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.3 - github.com/StackExchange/wmi v1.2.0 // indirect + github.com/StackExchange/wmi v1.2.1 // indirect github.com/go-ole/go-ole v1.2.5 // indirect github.com/robfig/cron v1.2.0 github.com/shirou/gopsutil v3.21.6+incompatible diff --git a/go.sum b/go.sum index 1ab5bc82..cf3ebffc 100644 --- a/go.sum +++ b/go.sum @@ -2,6 +2,8 @@ github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd h1:rvV66DIEqNJM github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd/go.mod h1:GYrQD70HvBzry1XiZ1tHFNOsOqRkR+ao4XGYZqV4I9c= github.com/FloatTech/ZeroBot-ACGImage v1.1.2 h1:Q+FwOb1vCCYG2B7hPU0uBMzWwB85eVlC0pWRJZ+rBCQ= github.com/FloatTech/ZeroBot-ACGImage v1.1.2/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= +github.com/FloatTech/ZeroBot-ACGImage v1.2.1 h1:GQR1dudKIPh13EKybH5o3GZys0m6Wy87BF5DpcNzutw= +github.com/FloatTech/ZeroBot-ACGImage v1.2.1/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4 h1:BMrSHJO1lWKTKU1DCK+XEpTaK38FMlBEIywFLIiatu8= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4/go.mod h1:femu/wVuqVSN/rg209qksMx8/2OKUF8l1PZCNg4RwVA= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.1 h1:AT/nudxY5murKpEyP+ZZTczknSipeZPP2tId6/2I7Nw= @@ -14,6 +16,8 @@ github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46 h1:5sXbqlSomvdjl github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46/go.mod h1:3eOhrUMpNV+6aFIbp5/iudMxNCF27Vw2OZgy4xEx0Fg= github.com/StackExchange/wmi v1.2.0 h1:noJEYkMQVlFCEAc+2ma5YyRhlfjcWfZqk5sBRYozdyM= github.com/StackExchange/wmi v1.2.0/go.mod h1:3eOhrUMpNV+6aFIbp5/iudMxNCF27Vw2OZgy4xEx0Fg= +github.com/StackExchange/wmi v1.2.1 h1:VIkavFPXSjcnS+O8yTq7NI32k0R5Aj+v39y29VYDOSA= +github.com/StackExchange/wmi v1.2.1/go.mod h1:rcmrprowKIVzvc+NUiLncP2uuArMWLCbu9SBzvHz7e8= github.com/antchfx/htmlquery v1.2.3 h1:sP3NFDneHx2stfNXCKbhHFo8XgNjCACnU/4AO5gWz6M= github.com/antchfx/htmlquery v1.2.3/go.mod h1:B0ABL+F5irhhMWg54ymEZinzMSi0Kt3I2if0BLYa3V0= github.com/antchfx/xpath v1.1.6 h1:6sVh6hB5T6phw1pFpHRQ+C4bd8sNI+O58flqtg7h0R0= From fa3b0d770e9ce040873f73b7c6e8ea0ec744b32b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=BA=90=E6=96=87=E9=9B=A8?= <41315874+fumiama@users.noreply.github.com> Date: Sat, 31 Jul 2021 20:14:56 +0800 Subject: [PATCH 22/79] Update README.md --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index b2d02b7e..7a6fc6b0 100644 --- a/README.md +++ b/README.md @@ -81,7 +81,7 @@ - [x] 以图搜图|搜索图片|以图识图[图片] - [x] 搜图[P站图片ID] - 随机图片与点评 `github.com/FloatTech/ZeroBot-Plugin/plugin_rand_image` - - [x] 随机图片(也有概率出r18,请务必小心) + - [x] 随机图片 - [x] 直接随机(无r18检测,后果自负) - [x] 设置随机图片网址[url] - [x] 太涩了(撤回最近发的图) From 77631a134246314c3ab4252201ef4ff1c3b75833 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=BA=90=E6=96=87=E9=9B=A8?= <41315874+fumiama@users.noreply.github.com> Date: Sat, 31 Jul 2021 20:19:34 +0800 Subject: [PATCH 23/79] =?UTF-8?q?=E2=9C=8F=EF=B8=8F=20=E4=BF=AE=E6=AD=A3?= =?UTF-8?q?=E9=9A=8F=E6=9C=BA=E5=9B=BE=E7=89=87=E8=AF=B4=E6=98=8E?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 7a6fc6b0..548811b6 100644 --- a/README.md +++ b/README.md @@ -82,7 +82,7 @@ - [x] 搜图[P站图片ID] - 随机图片与点评 `github.com/FloatTech/ZeroBot-Plugin/plugin_rand_image` - [x] 随机图片 - - [x] 直接随机(无r18检测,后果自负) + - [x] 直接随机(需要自己设置随机图片网址) - [x] 设置随机图片网址[url] - [x] 太涩了(撤回最近发的图) - [x] 评价图片:发送一张图片让bot评分 From 14b13fe9f3193af79ac5d40cde715df9d837247e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=BA=90=E6=96=87=E9=9B=A8?= <41315874+fumiama@users.noreply.github.com> Date: Sat, 31 Jul 2021 20:20:42 +0800 Subject: [PATCH 24/79] =?UTF-8?q?=E2=9C=8F=EF=B8=8F=20=E4=BF=AE=E6=AD=A3?= =?UTF-8?q?=E9=9A=8F=E6=9C=BA=E5=9B=BE=E7=89=87=E8=AF=B4=E6=98=8E?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 548811b6..6a8b0d8d 100644 --- a/README.md +++ b/README.md @@ -84,7 +84,7 @@ - [x] 随机图片 - [x] 直接随机(需要自己设置随机图片网址) - [x] 设置随机图片网址[url] - - [x] 太涩了(撤回最近发的图) + - [x] 太涩了(撤回最近发的图) - [x] 评价图片:发送一张图片让bot评分 - bilibili `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_bilibili"` - [x] >bili info [名字] From 41d83a37562a20fb2464c9374f9739b24a784f64 Mon Sep 17 00:00:00 2001 From: fumiama Date: Sun, 1 Aug 2021 13:15:43 +0800 Subject: [PATCH 25/79] =?UTF-8?q?=E5=AE=8C=E5=96=84=E9=9A=8F=E6=9C=BA?= =?UTF-8?q?=E5=9B=BE=E7=89=87=E4=B8=8EAI=E7=82=B9=E8=AF=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 6 +++--- go.mod | 2 +- go.sum | 4 ++++ main.go | 2 +- plugin_rand_image/rand_image.go | 5 ----- 5 files changed, 9 insertions(+), 10 deletions(-) delete mode 100644 plugin_rand_image/rand_image.go diff --git a/README.md b/README.md index 6a8b0d8d..0a100ad9 100644 --- a/README.md +++ b/README.md @@ -80,12 +80,12 @@ - 搜图 `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_saucenao"` - [x] 以图搜图|搜索图片|以图识图[图片] - [x] 搜图[P站图片ID] -- 随机图片与点评 `github.com/FloatTech/ZeroBot-Plugin/plugin_rand_image` +- 随机图片与AI点评 `github.com/FloatTech/ZeroBot-ACGImage` - [x] 随机图片 - - [x] 直接随机(需要自己设置随机图片网址) + - [x] 直接随机(无r18检测,务必小心,仅管理可用) - [x] 设置随机图片网址[url] - [x] 太涩了(撤回最近发的图) - - [x] 评价图片:发送一张图片让bot评分 + - [x] 评价图片(发送一张图片让bot评分) - bilibili `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_bilibili"` - [x] >bili info [名字] - 嘉然 `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_diana"` diff --git a/go.mod b/go.mod index 9a901c6e..c625cd45 100644 --- a/go.mod +++ b/go.mod @@ -4,7 +4,7 @@ go 1.16 require ( github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd - github.com/FloatTech/ZeroBot-ACGImage v1.2.1 + github.com/FloatTech/ZeroBot-ACGImage v1.3.3 github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.3 github.com/StackExchange/wmi v1.2.1 // indirect github.com/go-ole/go-ole v1.2.5 // indirect diff --git a/go.sum b/go.sum index cf3ebffc..b6ab1101 100644 --- a/go.sum +++ b/go.sum @@ -4,6 +4,10 @@ github.com/FloatTech/ZeroBot-ACGImage v1.1.2 h1:Q+FwOb1vCCYG2B7hPU0uBMzWwB85eVlC github.com/FloatTech/ZeroBot-ACGImage v1.1.2/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= github.com/FloatTech/ZeroBot-ACGImage v1.2.1 h1:GQR1dudKIPh13EKybH5o3GZys0m6Wy87BF5DpcNzutw= github.com/FloatTech/ZeroBot-ACGImage v1.2.1/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= +github.com/FloatTech/ZeroBot-ACGImage v1.3.1 h1:P9zfrVJcyFFViYz7qr/+DTD34oIpn5/hilmuhIeatwY= +github.com/FloatTech/ZeroBot-ACGImage v1.3.1/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= +github.com/FloatTech/ZeroBot-ACGImage v1.3.3 h1:Y1fZO9YAMM1wQBN+ZbOXCEKpp+8TrM5TwaUqgWffVsI= +github.com/FloatTech/ZeroBot-ACGImage v1.3.3/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4 h1:BMrSHJO1lWKTKU1DCK+XEpTaK38FMlBEIywFLIiatu8= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4/go.mod h1:femu/wVuqVSN/rg209qksMx8/2OKUF8l1PZCNg4RwVA= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.1 h1:AT/nudxY5murKpEyP+ZZTczknSipeZPP2tId6/2I7Nw= diff --git a/main.go b/main.go index 75653509..38bb2959 100644 --- a/main.go +++ b/main.go @@ -27,9 +27,9 @@ import ( _ "github.com/FloatTech/ZeroBot-Plugin/plugin_diana" // 嘉心糖发病 // 二次元图片 + _ "github.com/FloatTech/ZeroBot-ACGImage" // 随机图片与AI点评 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_image_finder" // 关键字搜图 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_lolicon" // lolicon 随机图片 - _ "github.com/FloatTech/ZeroBot-Plugin/plugin_rand_image" // 随机图片与点评 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_saucenao" // 以图搜图 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_setutime" // 来份涩图 diff --git a/plugin_rand_image/rand_image.go b/plugin_rand_image/rand_image.go deleted file mode 100644 index a601902e..00000000 --- a/plugin_rand_image/rand_image.go +++ /dev/null @@ -1,5 +0,0 @@ -package plugin_rand_image - -import ( - _ "github.com/FloatTech/ZeroBot-ACGImage" //简易随机图片 -) From a94e4e29682298411affe380cebb2bc2adf89ad4 Mon Sep 17 00:00:00 2001 From: fumiama Date: Sun, 1 Aug 2021 13:43:20 +0800 Subject: [PATCH 26/79] =?UTF-8?q?=E5=8D=87=E7=BA=A7ACGImage?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- go.mod | 2 +- go.sum | 2 ++ 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/go.mod b/go.mod index c625cd45..07571c35 100644 --- a/go.mod +++ b/go.mod @@ -4,7 +4,7 @@ go 1.16 require ( github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd - github.com/FloatTech/ZeroBot-ACGImage v1.3.3 + github.com/FloatTech/ZeroBot-ACGImage v1.3.4 github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.3 github.com/StackExchange/wmi v1.2.1 // indirect github.com/go-ole/go-ole v1.2.5 // indirect diff --git a/go.sum b/go.sum index b6ab1101..bd9ad27e 100644 --- a/go.sum +++ b/go.sum @@ -8,6 +8,8 @@ github.com/FloatTech/ZeroBot-ACGImage v1.3.1 h1:P9zfrVJcyFFViYz7qr/+DTD34oIpn5/h github.com/FloatTech/ZeroBot-ACGImage v1.3.1/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= github.com/FloatTech/ZeroBot-ACGImage v1.3.3 h1:Y1fZO9YAMM1wQBN+ZbOXCEKpp+8TrM5TwaUqgWffVsI= github.com/FloatTech/ZeroBot-ACGImage v1.3.3/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= +github.com/FloatTech/ZeroBot-ACGImage v1.3.4 h1:oyPYs9R+yKMCzTEgEZkP4yMOTs/GTvnQv0jQ6ulWdQo= +github.com/FloatTech/ZeroBot-ACGImage v1.3.4/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4 h1:BMrSHJO1lWKTKU1DCK+XEpTaK38FMlBEIywFLIiatu8= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4/go.mod h1:femu/wVuqVSN/rg209qksMx8/2OKUF8l1PZCNg4RwVA= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.1 h1:AT/nudxY5murKpEyP+ZZTczknSipeZPP2tId6/2I7Nw= From 987f29fc65670ec500af6c42093ae4651c5bec11 Mon Sep 17 00:00:00 2001 From: fumiama Date: Sun, 1 Aug 2021 15:58:18 +0800 Subject: [PATCH 27/79] =?UTF-8?q?=E5=8D=87=E7=BA=A7acgimage?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- go.mod | 2 +- go.sum | 2 ++ 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/go.mod b/go.mod index 07571c35..a6bdfbec 100644 --- a/go.mod +++ b/go.mod @@ -4,7 +4,7 @@ go 1.16 require ( github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd - github.com/FloatTech/ZeroBot-ACGImage v1.3.4 + github.com/FloatTech/ZeroBot-ACGImage v1.4.1 github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.3 github.com/StackExchange/wmi v1.2.1 // indirect github.com/go-ole/go-ole v1.2.5 // indirect diff --git a/go.sum b/go.sum index bd9ad27e..51fc9a29 100644 --- a/go.sum +++ b/go.sum @@ -10,6 +10,8 @@ github.com/FloatTech/ZeroBot-ACGImage v1.3.3 h1:Y1fZO9YAMM1wQBN+ZbOXCEKpp+8TrM5T github.com/FloatTech/ZeroBot-ACGImage v1.3.3/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= github.com/FloatTech/ZeroBot-ACGImage v1.3.4 h1:oyPYs9R+yKMCzTEgEZkP4yMOTs/GTvnQv0jQ6ulWdQo= github.com/FloatTech/ZeroBot-ACGImage v1.3.4/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= +github.com/FloatTech/ZeroBot-ACGImage v1.4.1 h1:P4Pjci0djSQ99nnCGnSLh6mh4Jq5qOL+PBQzAG0ZyZc= +github.com/FloatTech/ZeroBot-ACGImage v1.4.1/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4 h1:BMrSHJO1lWKTKU1DCK+XEpTaK38FMlBEIywFLIiatu8= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4/go.mod h1:femu/wVuqVSN/rg209qksMx8/2OKUF8l1PZCNg4RwVA= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.1 h1:AT/nudxY5murKpEyP+ZZTczknSipeZPP2tId6/2I7Nw= From 62ff4f4860b4ee307f4fa59c6dd418059217b2ae Mon Sep 17 00:00:00 2001 From: fumiama Date: Sun, 1 Aug 2021 16:07:55 +0800 Subject: [PATCH 28/79] =?UTF-8?q?=E5=8D=87=E7=BA=A7ACGImage=E3=80=81ZeroBo?= =?UTF-8?q?t-Plugin-Timer=E3=80=81gopsutil?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- go.mod | 6 +++--- go.sum | 6 ++++++ 2 files changed, 9 insertions(+), 3 deletions(-) diff --git a/go.mod b/go.mod index a6bdfbec..9cf95005 100644 --- a/go.mod +++ b/go.mod @@ -4,12 +4,12 @@ go 1.16 require ( github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd - github.com/FloatTech/ZeroBot-ACGImage v1.4.1 - github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.3 + github.com/FloatTech/ZeroBot-ACGImage v1.4.2 + github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4 github.com/StackExchange/wmi v1.2.1 // indirect github.com/go-ole/go-ole v1.2.5 // indirect github.com/robfig/cron v1.2.0 - github.com/shirou/gopsutil v3.21.6+incompatible + github.com/shirou/gopsutil v3.21.7+incompatible github.com/sirupsen/logrus v1.8.1 github.com/t-tomalak/logrus-easy-formatter v0.0.0-20190827215021-c074f06c5816 github.com/tidwall/gjson v1.8.1 diff --git a/go.sum b/go.sum index 51fc9a29..9bca28f1 100644 --- a/go.sum +++ b/go.sum @@ -12,6 +12,8 @@ github.com/FloatTech/ZeroBot-ACGImage v1.3.4 h1:oyPYs9R+yKMCzTEgEZkP4yMOTs/GTvnQ github.com/FloatTech/ZeroBot-ACGImage v1.3.4/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= github.com/FloatTech/ZeroBot-ACGImage v1.4.1 h1:P4Pjci0djSQ99nnCGnSLh6mh4Jq5qOL+PBQzAG0ZyZc= github.com/FloatTech/ZeroBot-ACGImage v1.4.1/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= +github.com/FloatTech/ZeroBot-ACGImage v1.4.2 h1:/jj/+5a4EeejeqIDkeUbaxpCpZfLPCODa3sw/1m/Das= +github.com/FloatTech/ZeroBot-ACGImage v1.4.2/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4 h1:BMrSHJO1lWKTKU1DCK+XEpTaK38FMlBEIywFLIiatu8= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4/go.mod h1:femu/wVuqVSN/rg209qksMx8/2OKUF8l1PZCNg4RwVA= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.1 h1:AT/nudxY5murKpEyP+ZZTczknSipeZPP2tId6/2I7Nw= @@ -20,6 +22,8 @@ github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.2 h1:mVkuGVtznDH1n0l00TJesmA5K2NZ github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.2/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.3 h1:NXk18XCfy4cCSMXru/NHfCdf26o3fBWOTuEvxFcweeg= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.3/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= +github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4 h1:nRJqY/S7TRlN32MQGIBH3UWfVrpjxpJXCnp42pd2O2Q= +github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46 h1:5sXbqlSomvdjlRbWyNqkPsJ3Fg+tQZCbgeX1VGljbQY= github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46/go.mod h1:3eOhrUMpNV+6aFIbp5/iudMxNCF27Vw2OZgy4xEx0Fg= github.com/StackExchange/wmi v1.2.0 h1:noJEYkMQVlFCEAc+2ma5YyRhlfjcWfZqk5sBRYozdyM= @@ -78,6 +82,8 @@ github.com/robfig/cron v1.2.0 h1:ZjScXvvxeQ63Dbyxy76Fj3AT3Ut0aKsyd2/tl3DTMuQ= github.com/robfig/cron v1.2.0/go.mod h1:JGuDeoQd7Z6yL4zQhZ3OPEVHB7fL6Ka6skscFHfmt2k= github.com/shirou/gopsutil v3.21.6+incompatible h1:mmZtAlWSd8U2HeRTjswbnDLPxqsEoK01NK+GZ1P+nEM= github.com/shirou/gopsutil v3.21.6+incompatible/go.mod h1:5b4v6he4MtMOwMlS0TUMTu2PcXUg8+E1lC7eC3UO/RA= +github.com/shirou/gopsutil v3.21.7+incompatible h1:g/wcPHcuCQvHSePVofjQljd2vX4ty0+J6VoMB+NPcdk= +github.com/shirou/gopsutil v3.21.7+incompatible/go.mod h1:5b4v6he4MtMOwMlS0TUMTu2PcXUg8+E1lC7eC3UO/RA= github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6MwdIuYE2rE= github.com/sirupsen/logrus v1.8.1 h1:dJKuHgqk1NNQlqoA6BTlM1Wf9DOH3NBjQyu0h9+AZZE= github.com/sirupsen/logrus v1.8.1/go.mod h1:yWOB1SBYBC5VeMP7gHvWumXLIWorT60ONWic61uBYv0= From d48110719f909b66a47c152fe90d57347cfd8238 Mon Sep 17 00:00:00 2001 From: fumiama Date: Sun, 1 Aug 2021 16:19:16 +0800 Subject: [PATCH 29/79] =?UTF-8?q?=E5=8D=87=E7=BA=A7ACGImage?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- go.mod | 2 +- go.sum | 2 ++ 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/go.mod b/go.mod index 9cf95005..910e7db4 100644 --- a/go.mod +++ b/go.mod @@ -4,7 +4,7 @@ go 1.16 require ( github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd - github.com/FloatTech/ZeroBot-ACGImage v1.4.2 + github.com/FloatTech/ZeroBot-ACGImage v1.4.3 github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4 github.com/StackExchange/wmi v1.2.1 // indirect github.com/go-ole/go-ole v1.2.5 // indirect diff --git a/go.sum b/go.sum index 9bca28f1..dbc6240d 100644 --- a/go.sum +++ b/go.sum @@ -14,6 +14,8 @@ github.com/FloatTech/ZeroBot-ACGImage v1.4.1 h1:P4Pjci0djSQ99nnCGnSLh6mh4Jq5qOL+ github.com/FloatTech/ZeroBot-ACGImage v1.4.1/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= github.com/FloatTech/ZeroBot-ACGImage v1.4.2 h1:/jj/+5a4EeejeqIDkeUbaxpCpZfLPCODa3sw/1m/Das= github.com/FloatTech/ZeroBot-ACGImage v1.4.2/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= +github.com/FloatTech/ZeroBot-ACGImage v1.4.3 h1:lQTKfrVYdO5T+4KfC8U2bIxYnZql2hG2tSo/msTGRcI= +github.com/FloatTech/ZeroBot-ACGImage v1.4.3/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4 h1:BMrSHJO1lWKTKU1DCK+XEpTaK38FMlBEIywFLIiatu8= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4/go.mod h1:femu/wVuqVSN/rg209qksMx8/2OKUF8l1PZCNg4RwVA= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.1 h1:AT/nudxY5murKpEyP+ZZTczknSipeZPP2tId6/2I7Nw= From bda336dff5ad2f6150e3e3ace47b673738eb1ccd Mon Sep 17 00:00:00 2001 From: fumiama Date: Tue, 3 Aug 2021 01:01:43 +0800 Subject: [PATCH 30/79] =?UTF-8?q?=E5=8D=87=E7=BA=A7ACGImage=EF=BC=8C?= =?UTF-8?q?=E9=9A=90=E8=97=8F=E4=B8=80=E4=BA=9B=E5=8C=85=E6=9A=B4=E9=9C=B2?= =?UTF-8?q?=E7=9A=84=E5=87=BD=E6=95=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- go.mod | 3 ++- go.sum | 4 ++++ plugin_lolicon/lolicon.go | 15 ++++++++------- plugin_setutime/setu_geter.go | 16 ++++++++-------- plugin_setutime/sqlite.go | 1 - 5 files changed, 22 insertions(+), 17 deletions(-) diff --git a/go.mod b/go.mod index 910e7db4..82e24642 100644 --- a/go.mod +++ b/go.mod @@ -4,8 +4,9 @@ go 1.16 require ( github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd - github.com/FloatTech/ZeroBot-ACGImage v1.4.3 + github.com/FloatTech/ZeroBot-ACGImage v1.5.1 github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4 + github.com/FloatTech/Zerobot-ACGImage-Classify v1.2.1 github.com/StackExchange/wmi v1.2.1 // indirect github.com/go-ole/go-ole v1.2.5 // indirect github.com/robfig/cron v1.2.0 diff --git a/go.sum b/go.sum index dbc6240d..b0b462a6 100644 --- a/go.sum +++ b/go.sum @@ -16,6 +16,8 @@ github.com/FloatTech/ZeroBot-ACGImage v1.4.2 h1:/jj/+5a4EeejeqIDkeUbaxpCpZfLPCOD github.com/FloatTech/ZeroBot-ACGImage v1.4.2/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= github.com/FloatTech/ZeroBot-ACGImage v1.4.3 h1:lQTKfrVYdO5T+4KfC8U2bIxYnZql2hG2tSo/msTGRcI= github.com/FloatTech/ZeroBot-ACGImage v1.4.3/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= +github.com/FloatTech/ZeroBot-ACGImage v1.5.1 h1:iolon1PR4AjEJJmUHEDfCXL8tBZOx5W21hRvNirX1Bw= +github.com/FloatTech/ZeroBot-ACGImage v1.5.1/go.mod h1:Q9k43tGy2c5sDxw3XZc2An4YfqkN1wWIXeXUH2GlaBg= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4 h1:BMrSHJO1lWKTKU1DCK+XEpTaK38FMlBEIywFLIiatu8= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4/go.mod h1:femu/wVuqVSN/rg209qksMx8/2OKUF8l1PZCNg4RwVA= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.1 h1:AT/nudxY5murKpEyP+ZZTczknSipeZPP2tId6/2I7Nw= @@ -26,6 +28,8 @@ github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.3 h1:NXk18XCfy4cCSMXru/NHfCdf26o3 github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.3/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4 h1:nRJqY/S7TRlN32MQGIBH3UWfVrpjxpJXCnp42pd2O2Q= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= +github.com/FloatTech/Zerobot-ACGImage-Classify v1.2.1 h1:HEdT6yq06lV94jcArutpyqQLaPpczs0bTd6gdwVG1ps= +github.com/FloatTech/Zerobot-ACGImage-Classify v1.2.1/go.mod h1:swPvVKyXu1YFWZ7Kt6R79LgIa16hs4cE1E5LroBB2SQ= github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46 h1:5sXbqlSomvdjlRbWyNqkPsJ3Fg+tQZCbgeX1VGljbQY= github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46/go.mod h1:3eOhrUMpNV+6aFIbp5/iudMxNCF27Vw2OZgy4xEx0Fg= github.com/StackExchange/wmi v1.2.0 h1:noJEYkMQVlFCEAc+2ma5YyRhlfjcWfZqk5sBRYozdyM= diff --git a/plugin_lolicon/lolicon.go b/plugin_lolicon/lolicon.go index 8330ba55..22c0d6ea 100644 --- a/plugin_lolicon/lolicon.go +++ b/plugin_lolicon/lolicon.go @@ -26,13 +26,6 @@ func init() { zero.OnFullMatch("来份萝莉"). Handle(func(ctx *zero.Ctx) { go func() { - min := func(a, b int) int { - if a < b { - return a - } else { - return b - } - } for i := 0; i < min(cap(QUEUE)-len(QUEUE), 2); i++ { resp, err := http.Get(API) if err != nil { @@ -63,3 +56,11 @@ func init() { } }) } + +func min(a, b int) int { + if a < b { + return a + } else { + return b + } +} diff --git a/plugin_setutime/setu_geter.go b/plugin_setutime/setu_geter.go index a0b58eb1..54325069 100644 --- a/plugin_setutime/setu_geter.go +++ b/plugin_setutime/setu_geter.go @@ -56,7 +56,7 @@ var ( ) func init() { // 插件主体 - zero.OnRegex(`^来份(.*)$`, FirstValueInList(POOL.List)).SetBlock(true).SetPriority(20). + zero.OnRegex(`^来份(.*)$`, firstValueInList(POOL.List)).SetBlock(true).SetPriority(20). Handle(func(ctx *zero.Ctx) { if !limit.Load(ctx.Event.UserID).Acquire() { ctx.SendChain(message.Text("请稍后重试0x0...")) @@ -65,7 +65,7 @@ func init() { // 插件主体 var type_ = ctx.State["regex_matched"].([]string)[1] // 补充池子 go func() { - times := Min(POOL.Max-POOL.Size(type_), 2) + times := min(POOL.Max-POOL.Size(type_), 2) for i := 0; i < times; i++ { illust := &pixiv.Illust{} // 查询出一张图片 @@ -101,7 +101,7 @@ func init() { // 插件主体 return }) - zero.OnRegex(`^添加(.*?)(\d+)$`, FirstValueInList(POOL.List), zero.SuperUserPermission).SetBlock(true).SetPriority(21). + zero.OnRegex(`^添加(.*?)(\d+)$`, firstValueInList(POOL.List), zero.SuperUserPermission).SetBlock(true).SetPriority(21). Handle(func(ctx *zero.Ctx) { var ( type_ = ctx.State["regex_matched"].([]string)[1] @@ -133,7 +133,7 @@ func init() { // 插件主体 return }) - zero.OnRegex(`^删除(.*?)(\d+)$`, FirstValueInList(POOL.List), zero.SuperUserPermission).SetBlock(true).SetPriority(22). + zero.OnRegex(`^删除(.*?)(\d+)$`, firstValueInList(POOL.List), zero.SuperUserPermission).SetBlock(true).SetPriority(22). Handle(func(ctx *zero.Ctx) { var ( type_ = ctx.State["regex_matched"].([]string)[1] @@ -167,8 +167,8 @@ func init() { // 插件主体 }) } -// FirstValueInList 判断正则匹配的第一个参数是否在列表中 -func FirstValueInList(list []string) zero.Rule { +// firstValueInList 判断正则匹配的第一个参数是否在列表中 +func firstValueInList(list []string) zero.Rule { return func(ctx *zero.Ctx) bool { first := ctx.State["regex_matched"].([]string)[1] for i := range list { @@ -180,8 +180,8 @@ func FirstValueInList(list []string) zero.Rule { } } -// Min 返回两数最小值 -func Min(a, b int) int { +// min 返回两数最小值 +func min(a, b int) int { switch { default: return a diff --git a/plugin_setutime/sqlite.go b/plugin_setutime/sqlite.go index 6128b061..f25f801b 100644 --- a/plugin_setutime/sqlite.go +++ b/plugin_setutime/sqlite.go @@ -133,7 +133,6 @@ func (db *Sqlite) Select(table string, objptr interface{}, condition string) (er if err != nil { return err } - return nil } return errors.New("数据库无此条件项目") } From 36ca320922d1fbaaa27dc3d55a7d9b9f067a370f Mon Sep 17 00:00:00 2001 From: fumiama Date: Tue, 3 Aug 2021 01:04:58 +0800 Subject: [PATCH 31/79] =?UTF-8?q?=E5=88=A0=E9=99=A4=E6=97=A0=E7=94=A8?= =?UTF-8?q?=E8=AF=AD=E5=8F=A5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_setutime/sqlite.go | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/plugin_setutime/sqlite.go b/plugin_setutime/sqlite.go index f25f801b..2d9ce597 100644 --- a/plugin_setutime/sqlite.go +++ b/plugin_setutime/sqlite.go @@ -2,7 +2,6 @@ package plugin_setutime import ( "database/sql" - "errors" "reflect" "strings" @@ -134,7 +133,7 @@ func (db *Sqlite) Select(table string, objptr interface{}, condition string) (er return err } } - return errors.New("数据库无此条件项目") + return nil } // Delete 删除数据库 From 1675a4446f14d79ba22c777058903477d0799179 Mon Sep 17 00:00:00 2001 From: fumiama Date: Tue, 3 Aug 2021 23:56:32 +0800 Subject: [PATCH 32/79] =?UTF-8?q?ACGImage=E6=94=AF=E6=8C=81=E7=A7=81?= =?UTF-8?q?=E5=8F=91?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 2 +- go.mod | 4 ++-- go.sum | 16 ++++++++++++++++ main.go | 11 ++++++----- 4 files changed, 25 insertions(+), 8 deletions(-) diff --git a/README.md b/README.md index 0a100ad9..83e3d90d 100644 --- a/README.md +++ b/README.md @@ -81,7 +81,7 @@ - [x] 以图搜图|搜索图片|以图识图[图片] - [x] 搜图[P站图片ID] - 随机图片与AI点评 `github.com/FloatTech/ZeroBot-ACGImage` - - [x] 随机图片 + - [x] 随机图片(评级大于6的图将私发) - [x] 直接随机(无r18检测,务必小心,仅管理可用) - [x] 设置随机图片网址[url] - [x] 太涩了(撤回最近发的图) diff --git a/go.mod b/go.mod index 82e24642..00951725 100644 --- a/go.mod +++ b/go.mod @@ -4,9 +4,9 @@ go 1.16 require ( github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd - github.com/FloatTech/ZeroBot-ACGImage v1.5.1 + github.com/FloatTech/ZeroBot-ACGImage v1.5.5 github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4 - github.com/FloatTech/Zerobot-ACGImage-Classify v1.2.1 + github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.3 github.com/StackExchange/wmi v1.2.1 // indirect github.com/go-ole/go-ole v1.2.5 // indirect github.com/robfig/cron v1.2.0 diff --git a/go.sum b/go.sum index b0b462a6..2b5b0e84 100644 --- a/go.sum +++ b/go.sum @@ -18,6 +18,14 @@ github.com/FloatTech/ZeroBot-ACGImage v1.4.3 h1:lQTKfrVYdO5T+4KfC8U2bIxYnZql2hG2 github.com/FloatTech/ZeroBot-ACGImage v1.4.3/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= github.com/FloatTech/ZeroBot-ACGImage v1.5.1 h1:iolon1PR4AjEJJmUHEDfCXL8tBZOx5W21hRvNirX1Bw= github.com/FloatTech/ZeroBot-ACGImage v1.5.1/go.mod h1:Q9k43tGy2c5sDxw3XZc2An4YfqkN1wWIXeXUH2GlaBg= +github.com/FloatTech/ZeroBot-ACGImage v1.5.2 h1:jiwZd5KEqtiKAY5QsUa6LqtW0+c1ZTg5ffqDiyDpXA8= +github.com/FloatTech/ZeroBot-ACGImage v1.5.2/go.mod h1:BWZWhP/ZVtSRTkI7CHcLO2+E7kQ/kaMPrZkMMT9VNAc= +github.com/FloatTech/ZeroBot-ACGImage v1.5.3 h1:wgG7S8z+LeoCf2nkkJ3CmOX1g5JgH47TfdBMM3KSlBA= +github.com/FloatTech/ZeroBot-ACGImage v1.5.3/go.mod h1:E2hb+uQdzpiq+kB/EoOHgMFhLt61rGDz8hNiGcZr2wo= +github.com/FloatTech/ZeroBot-ACGImage v1.5.4 h1:jPS962qvBmOR+wy8qj6wpScYZv0pLKdnl5fKdFBjNEw= +github.com/FloatTech/ZeroBot-ACGImage v1.5.4/go.mod h1:olj7sxGxAPrxy9JmbfVwkCNxrVYJ7SKnp42WbEKvWD8= +github.com/FloatTech/ZeroBot-ACGImage v1.5.5 h1:cmAsXHl99RHJR38vQXL+q/U0BGWg5LyMHxBw5Mf8f1o= +github.com/FloatTech/ZeroBot-ACGImage v1.5.5/go.mod h1:TDGCgGHKjgcnA0akLaEwUcFwL+/ya7p6PZITdJQ1vnQ= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4 h1:BMrSHJO1lWKTKU1DCK+XEpTaK38FMlBEIywFLIiatu8= github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4/go.mod h1:femu/wVuqVSN/rg209qksMx8/2OKUF8l1PZCNg4RwVA= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.1 h1:AT/nudxY5murKpEyP+ZZTczknSipeZPP2tId6/2I7Nw= @@ -30,6 +38,14 @@ github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4 h1:nRJqY/S7TRlN32MQGIBH3UWfVrpj github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= github.com/FloatTech/Zerobot-ACGImage-Classify v1.2.1 h1:HEdT6yq06lV94jcArutpyqQLaPpczs0bTd6gdwVG1ps= github.com/FloatTech/Zerobot-ACGImage-Classify v1.2.1/go.mod h1:swPvVKyXu1YFWZ7Kt6R79LgIa16hs4cE1E5LroBB2SQ= +github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.0 h1:4lwSBYlwPsUE7uDzSaTH4/ZlaQwWbF1jeincg6eOByg= +github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.0/go.mod h1:swPvVKyXu1YFWZ7Kt6R79LgIa16hs4cE1E5LroBB2SQ= +github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.1 h1:T8cSLwoVppbMRPKnwFgItl8523BFBiyYjxo81KXGZFk= +github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.1/go.mod h1:swPvVKyXu1YFWZ7Kt6R79LgIa16hs4cE1E5LroBB2SQ= +github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.2 h1:7s06Cw2TggudMEz3t+OSAiSv/JAetNdNYgfmuLZhGwU= +github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.2/go.mod h1:swPvVKyXu1YFWZ7Kt6R79LgIa16hs4cE1E5LroBB2SQ= +github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.3 h1:mMaBe23yg8mk5U0yb9OS9iX/9hju6Dj+Z+Fty18vIhU= +github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.3/go.mod h1:swPvVKyXu1YFWZ7Kt6R79LgIa16hs4cE1E5LroBB2SQ= github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46 h1:5sXbqlSomvdjlRbWyNqkPsJ3Fg+tQZCbgeX1VGljbQY= github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46/go.mod h1:3eOhrUMpNV+6aFIbp5/iudMxNCF27Vw2OZgy4xEx0Fg= github.com/StackExchange/wmi v1.2.0 h1:noJEYkMQVlFCEAc+2ma5YyRhlfjcWfZqk5sBRYozdyM= diff --git a/main.go b/main.go index 38bb2959..55501ef2 100644 --- a/main.go +++ b/main.go @@ -18,7 +18,7 @@ import ( // 娱乐类 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_ai_false" // 服务器监控 - _ "github.com/FloatTech/ZeroBot-Plugin/plugin_minecraft" + //_ "github.com/FloatTech/ZeroBot-Plugin/plugin_minecraft" _ "github.com/FloatTech/ZeroBot-Plugin/plugin_music" // 点歌 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_shindan" // 测定 @@ -29,9 +29,10 @@ import ( // 二次元图片 _ "github.com/FloatTech/ZeroBot-ACGImage" // 随机图片与AI点评 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_image_finder" // 关键字搜图 - _ "github.com/FloatTech/ZeroBot-Plugin/plugin_lolicon" // lolicon 随机图片 - _ "github.com/FloatTech/ZeroBot-Plugin/plugin_saucenao" // 以图搜图 - _ "github.com/FloatTech/ZeroBot-Plugin/plugin_setutime" // 来份涩图 + + //_ "github.com/FloatTech/ZeroBot-Plugin/plugin_lolicon" // lolicon 随机图片 + _ "github.com/FloatTech/ZeroBot-Plugin/plugin_saucenao" // 以图搜图 + //_ "github.com/FloatTech/ZeroBot-Plugin/plugin_setutime" // 来份涩图 // 以下为内置依赖,勿动 zero "github.com/wdvxdr1123/ZeroBot" @@ -70,7 +71,7 @@ func main() { // SuperUsers 某些功能需要主人权限,可通过以下两种方式修改 // []string{}:通过代码写死的方式添加主人账号 // os.Args[1:]:通过命令行参数的方式添加主人账号 - SuperUsers: append([]string{"12345678", "87654321"}, os.Args[1:]...), + SuperUsers: os.Args[1:], Driver: []zero.Driver{ &driver.WSClient{ From 0d1da0877acaf82e9a30f20c7c3f356bb34955ad Mon Sep 17 00:00:00 2001 From: fumiama Date: Wed, 4 Aug 2021 00:09:54 +0800 Subject: [PATCH 33/79] =?UTF-8?q?=E5=88=A0=E9=99=A4indirect?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- go.mod | 2 -- 1 file changed, 2 deletions(-) diff --git a/go.mod b/go.mod index 00951725..acd5d750 100644 --- a/go.mod +++ b/go.mod @@ -6,9 +6,7 @@ require ( github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd github.com/FloatTech/ZeroBot-ACGImage v1.5.5 github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4 - github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.3 github.com/StackExchange/wmi v1.2.1 // indirect - github.com/go-ole/go-ole v1.2.5 // indirect github.com/robfig/cron v1.2.0 github.com/shirou/gopsutil v3.21.7+incompatible github.com/sirupsen/logrus v1.8.1 From b6533472c8f4c7d53c7a23955d0ce4b4388df28a Mon Sep 17 00:00:00 2001 From: fumiama Date: Wed, 4 Aug 2021 00:10:05 +0800 Subject: [PATCH 34/79] =?UTF-8?q?=E5=88=A0=E9=99=A4indirect?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- go.sum | 64 +-------------------------------------------------------- main.go | 11 +++++----- 2 files changed, 6 insertions(+), 69 deletions(-) diff --git a/go.sum b/go.sum index 2b5b0e84..c47fe794 100644 --- a/go.sum +++ b/go.sum @@ -1,55 +1,11 @@ github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd h1:rvV66DIEqNJMEKwYXDJvw6kpJuGg+Pz/BooewuTBjXs= github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd/go.mod h1:GYrQD70HvBzry1XiZ1tHFNOsOqRkR+ao4XGYZqV4I9c= -github.com/FloatTech/ZeroBot-ACGImage v1.1.2 h1:Q+FwOb1vCCYG2B7hPU0uBMzWwB85eVlC0pWRJZ+rBCQ= -github.com/FloatTech/ZeroBot-ACGImage v1.1.2/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= -github.com/FloatTech/ZeroBot-ACGImage v1.2.1 h1:GQR1dudKIPh13EKybH5o3GZys0m6Wy87BF5DpcNzutw= -github.com/FloatTech/ZeroBot-ACGImage v1.2.1/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= -github.com/FloatTech/ZeroBot-ACGImage v1.3.1 h1:P9zfrVJcyFFViYz7qr/+DTD34oIpn5/hilmuhIeatwY= -github.com/FloatTech/ZeroBot-ACGImage v1.3.1/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= -github.com/FloatTech/ZeroBot-ACGImage v1.3.3 h1:Y1fZO9YAMM1wQBN+ZbOXCEKpp+8TrM5TwaUqgWffVsI= -github.com/FloatTech/ZeroBot-ACGImage v1.3.3/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= -github.com/FloatTech/ZeroBot-ACGImage v1.3.4 h1:oyPYs9R+yKMCzTEgEZkP4yMOTs/GTvnQv0jQ6ulWdQo= -github.com/FloatTech/ZeroBot-ACGImage v1.3.4/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= -github.com/FloatTech/ZeroBot-ACGImage v1.4.1 h1:P4Pjci0djSQ99nnCGnSLh6mh4Jq5qOL+PBQzAG0ZyZc= -github.com/FloatTech/ZeroBot-ACGImage v1.4.1/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= -github.com/FloatTech/ZeroBot-ACGImage v1.4.2 h1:/jj/+5a4EeejeqIDkeUbaxpCpZfLPCODa3sw/1m/Das= -github.com/FloatTech/ZeroBot-ACGImage v1.4.2/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= -github.com/FloatTech/ZeroBot-ACGImage v1.4.3 h1:lQTKfrVYdO5T+4KfC8U2bIxYnZql2hG2tSo/msTGRcI= -github.com/FloatTech/ZeroBot-ACGImage v1.4.3/go.mod h1:CtEYnFTjgzH4v1jaowyyjBmjSKK3p8WPXExfGnVmx1E= -github.com/FloatTech/ZeroBot-ACGImage v1.5.1 h1:iolon1PR4AjEJJmUHEDfCXL8tBZOx5W21hRvNirX1Bw= -github.com/FloatTech/ZeroBot-ACGImage v1.5.1/go.mod h1:Q9k43tGy2c5sDxw3XZc2An4YfqkN1wWIXeXUH2GlaBg= -github.com/FloatTech/ZeroBot-ACGImage v1.5.2 h1:jiwZd5KEqtiKAY5QsUa6LqtW0+c1ZTg5ffqDiyDpXA8= -github.com/FloatTech/ZeroBot-ACGImage v1.5.2/go.mod h1:BWZWhP/ZVtSRTkI7CHcLO2+E7kQ/kaMPrZkMMT9VNAc= -github.com/FloatTech/ZeroBot-ACGImage v1.5.3 h1:wgG7S8z+LeoCf2nkkJ3CmOX1g5JgH47TfdBMM3KSlBA= -github.com/FloatTech/ZeroBot-ACGImage v1.5.3/go.mod h1:E2hb+uQdzpiq+kB/EoOHgMFhLt61rGDz8hNiGcZr2wo= -github.com/FloatTech/ZeroBot-ACGImage v1.5.4 h1:jPS962qvBmOR+wy8qj6wpScYZv0pLKdnl5fKdFBjNEw= -github.com/FloatTech/ZeroBot-ACGImage v1.5.4/go.mod h1:olj7sxGxAPrxy9JmbfVwkCNxrVYJ7SKnp42WbEKvWD8= github.com/FloatTech/ZeroBot-ACGImage v1.5.5 h1:cmAsXHl99RHJR38vQXL+q/U0BGWg5LyMHxBw5Mf8f1o= github.com/FloatTech/ZeroBot-ACGImage v1.5.5/go.mod h1:TDGCgGHKjgcnA0akLaEwUcFwL+/ya7p6PZITdJQ1vnQ= -github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4 h1:BMrSHJO1lWKTKU1DCK+XEpTaK38FMlBEIywFLIiatu8= -github.com/FloatTech/ZeroBot-Plugin-Timer v1.2.4/go.mod h1:femu/wVuqVSN/rg209qksMx8/2OKUF8l1PZCNg4RwVA= -github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.1 h1:AT/nudxY5murKpEyP+ZZTczknSipeZPP2tId6/2I7Nw= -github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.1/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= -github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.2 h1:mVkuGVtznDH1n0l00TJesmA5K2NZ+98OaXcqyPh6TVM= -github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.2/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= -github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.3 h1:NXk18XCfy4cCSMXru/NHfCdf26o3fBWOTuEvxFcweeg= -github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.3/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4 h1:nRJqY/S7TRlN32MQGIBH3UWfVrpjxpJXCnp42pd2O2Q= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= -github.com/FloatTech/Zerobot-ACGImage-Classify v1.2.1 h1:HEdT6yq06lV94jcArutpyqQLaPpczs0bTd6gdwVG1ps= -github.com/FloatTech/Zerobot-ACGImage-Classify v1.2.1/go.mod h1:swPvVKyXu1YFWZ7Kt6R79LgIa16hs4cE1E5LroBB2SQ= -github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.0 h1:4lwSBYlwPsUE7uDzSaTH4/ZlaQwWbF1jeincg6eOByg= -github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.0/go.mod h1:swPvVKyXu1YFWZ7Kt6R79LgIa16hs4cE1E5LroBB2SQ= -github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.1 h1:T8cSLwoVppbMRPKnwFgItl8523BFBiyYjxo81KXGZFk= -github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.1/go.mod h1:swPvVKyXu1YFWZ7Kt6R79LgIa16hs4cE1E5LroBB2SQ= -github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.2 h1:7s06Cw2TggudMEz3t+OSAiSv/JAetNdNYgfmuLZhGwU= -github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.2/go.mod h1:swPvVKyXu1YFWZ7Kt6R79LgIa16hs4cE1E5LroBB2SQ= github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.3 h1:mMaBe23yg8mk5U0yb9OS9iX/9hju6Dj+Z+Fty18vIhU= github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.3/go.mod h1:swPvVKyXu1YFWZ7Kt6R79LgIa16hs4cE1E5LroBB2SQ= -github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46 h1:5sXbqlSomvdjlRbWyNqkPsJ3Fg+tQZCbgeX1VGljbQY= -github.com/StackExchange/wmi v0.0.0-20210224194228-fe8f1750fd46/go.mod h1:3eOhrUMpNV+6aFIbp5/iudMxNCF27Vw2OZgy4xEx0Fg= -github.com/StackExchange/wmi v1.2.0 h1:noJEYkMQVlFCEAc+2ma5YyRhlfjcWfZqk5sBRYozdyM= -github.com/StackExchange/wmi v1.2.0/go.mod h1:3eOhrUMpNV+6aFIbp5/iudMxNCF27Vw2OZgy4xEx0Fg= github.com/StackExchange/wmi v1.2.1 h1:VIkavFPXSjcnS+O8yTq7NI32k0R5Aj+v39y29VYDOSA= github.com/StackExchange/wmi v1.2.1/go.mod h1:rcmrprowKIVzvc+NUiLncP2uuArMWLCbu9SBzvHz7e8= github.com/antchfx/htmlquery v1.2.3 h1:sP3NFDneHx2stfNXCKbhHFo8XgNjCACnU/4AO5gWz6M= @@ -85,8 +41,7 @@ github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51/go.mod h1:C github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= github.com/mattn/go-isatty v0.0.12 h1:wuysRhFDzyxgEmMf5xjvJ2M9dZoWAXNNr5LSBS7uHXY= github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Kysco4FUpU= -github.com/mattn/go-sqlite3 v1.14.6 h1:dNPt6NO46WmLVt2DLNpwczCmdV5boIZ6g/tlDrlRUbg= -github.com/mattn/go-sqlite3 v1.14.6/go.mod h1:NyWgC/yNuGj7Q9rpYnZvas74GogHl5/Z4A/KQRfk6bU= +github.com/mattn/go-sqlite3 v1.14.8 h1:gDp86IdQsN/xWjIEmr9MF6o9mpksUgh0fu+9ByFxzIU= github.com/mattn/go-sqlite3 v1.14.8/go.mod h1:NyWgC/yNuGj7Q9rpYnZvas74GogHl5/Z4A/KQRfk6bU= github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421 h1:ZqeYNhU3OHLH3mGKHDcjJRFFRrJa6eAM5H+CtDdOsPc= github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= @@ -102,8 +57,6 @@ github.com/remyoudompheng/bigfft v0.0.0-20200410134404-eec4a21b6bb0 h1:OdAsTTz6O github.com/remyoudompheng/bigfft v0.0.0-20200410134404-eec4a21b6bb0/go.mod h1:qqbHyh8v60DhA7CoWK5oRCqLrMHRGoxYCSS9EjAz6Eo= github.com/robfig/cron v1.2.0 h1:ZjScXvvxeQ63Dbyxy76Fj3AT3Ut0aKsyd2/tl3DTMuQ= github.com/robfig/cron v1.2.0/go.mod h1:JGuDeoQd7Z6yL4zQhZ3OPEVHB7fL6Ka6skscFHfmt2k= -github.com/shirou/gopsutil v3.21.6+incompatible h1:mmZtAlWSd8U2HeRTjswbnDLPxqsEoK01NK+GZ1P+nEM= -github.com/shirou/gopsutil v3.21.6+incompatible/go.mod h1:5b4v6he4MtMOwMlS0TUMTu2PcXUg8+E1lC7eC3UO/RA= github.com/shirou/gopsutil v3.21.7+incompatible h1:g/wcPHcuCQvHSePVofjQljd2vX4ty0+J6VoMB+NPcdk= github.com/shirou/gopsutil v3.21.7+incompatible/go.mod h1:5b4v6he4MtMOwMlS0TUMTu2PcXUg8+E1lC7eC3UO/RA= github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6MwdIuYE2rE= @@ -126,16 +79,10 @@ github.com/tidwall/match v1.0.3/go.mod h1:eRSPERbgtNPcGhD8UCthc6PmLEQXEWd3PRB5JT github.com/tidwall/pretty v1.1.0/go.mod h1:XNkn88O1ChpSDQmQeStsy+sBenx6DDtFZJxhVysOjyk= github.com/tidwall/pretty v1.2.0 h1:RWIZEg2iJ8/g6fDDYzMpobmaoGh5OLl4AXtGUGPcqCs= github.com/tidwall/pretty v1.2.0/go.mod h1:ITEVvHYasfjBbM0u2Pg8T2nJnzm8xPwvNhhsoaGGjNU= -github.com/tklauser/go-sysconf v0.3.6 h1:oc1sJWvKkmvIxhDHeKWvZS4f6AW+YcoguSfRF2/Hmo4= -github.com/tklauser/go-sysconf v0.3.6/go.mod h1:MkWzOF4RMCshBAMXuhXJs64Rte09mITnppBXY/rYEFI= github.com/tklauser/go-sysconf v0.3.7 h1:HT7h4+536gjqeq1ZIJPgOl1rg1XFatQGVZWp7Py53eg= github.com/tklauser/go-sysconf v0.3.7/go.mod h1:JZIdXh4RmBvZDBZ41ld2bGxRV3n4daiiqA3skYhAoQ4= -github.com/tklauser/numcpus v0.2.2 h1:oyhllyrScuYI6g+h/zUvNXNp1wy7x8qQy3t/piefldA= -github.com/tklauser/numcpus v0.2.2/go.mod h1:x3qojaO3uyYt0i56EW/VUYs7uBvdl2fkfZFu0T9wgjM= github.com/tklauser/numcpus v0.2.3 h1:nQ0QYpiritP6ViFhrKYsiv6VVxOpum2Gks5GhnJbS/8= github.com/tklauser/numcpus v0.2.3/go.mod h1:vpEPS/JC+oZGGQ/My/vJnNsvMDQL6PwOqt8dsCw5j+E= -github.com/wdvxdr1123/ZeroBot v1.2.1 h1:ougeP+VOAGlQWCAUSB7fjA5trzEvPepU7pujsoYTCq8= -github.com/wdvxdr1123/ZeroBot v1.2.1/go.mod h1:83nHtG8V5TAxPwH/LCDxLpZk4khIgs29dkr5TBWf7fc= github.com/wdvxdr1123/ZeroBot v1.2.2 h1:BKEy3l80BMrQWpFWaII0AfFMyf9bqrB0TxfWhTdoV58= github.com/wdvxdr1123/ZeroBot v1.2.2/go.mod h1:83nHtG8V5TAxPwH/LCDxLpZk4khIgs29dkr5TBWf7fc= github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= @@ -169,9 +116,7 @@ golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7w golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20201126233918-771906719818/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210124154548-22da62e12c0c/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20210316164454-77fc1eacc6aa/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210330210617-4fbd30eecc44/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20210510120138-977fb7262007 h1:gG67DSER+11cZvqIMb8S8bt0vZtiN6xWYARwirrOSfE= golang.org/x/sys v0.0.0-20210510120138-977fb7262007/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c h1:F1jZWGFhYfh0Ci55sIpILtKKK8p3i2/krTr0H1rg74I= golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= @@ -183,8 +128,6 @@ golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= golang.org/x/tools v0.0.0-20201124115921-2c860bdd6e78/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= -golang.org/x/tools v0.1.3-0.20210608163600-9ed039809d4c h1:Pv9gNyJFYVdpUAVZYJ1BDSU4eGgXQ+0f3DIGAdolO5s= -golang.org/x/tools v0.1.3-0.20210608163600-9ed039809d4c/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= golang.org/x/tools v0.1.5 h1:ouewzE6p+/VEB31YYnTbEJdi8pFqKp4P4n85vwo3DHA= golang.org/x/tools v0.1.5/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= @@ -203,11 +146,9 @@ gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c h1:dUUwHk2QECo/6vqA44rthZ8ie gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= lukechampine.com/uint128 v1.1.1 h1:pnxCASz787iMf+02ssImqk6OLt+Z5QHMoZyUXR4z6JU= lukechampine.com/uint128 v1.1.1/go.mod h1:c4eWIwlEGaxC/+H1VguhU4PHXNWDCDMUlWdIWl2j1gk= -modernc.org/cc/v3 v3.33.6 h1:r63dgSzVzRxUpAJFPQWHy1QeZeY1ydNENUDaBx1GqYc= modernc.org/cc/v3 v3.33.6/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g= modernc.org/cc/v3 v3.33.7 h1:Rvxffgx6LHSpGS6IO8bffSYN1wpPsWHEWY9CV95vpro= modernc.org/cc/v3 v3.33.7/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g= -modernc.org/ccgo/v3 v3.9.5 h1:dEuUSf8WN51rDkprFuAqjfchKEzN0WttP/Py3enBwjk= modernc.org/ccgo/v3 v3.9.5/go.mod h1:umuo2EP2oDSBnD3ckjaVUXMrmeAw8C8OSICVa0iFf60= modernc.org/ccgo/v3 v3.9.6 h1:rCjLgu6iRxK2bqq8A0CCOnDP+tdA81LfbBUlM1L6ZIY= modernc.org/ccgo/v3 v3.9.6/go.mod h1:KGOi0NhaT6CO19xeSXcpXBl0OkoD6T1U4dPd633G9Sg= @@ -219,7 +160,6 @@ modernc.org/libc v1.9.11 h1:QUxZMs48Ahg2F7SN41aERvMfGLY2HU/ADnB9DC4Yts8= modernc.org/libc v1.9.11/go.mod h1:NyF3tsA5ArIjJ83XB0JlqhjTabTCHm9aX4XMPHyQn0Q= modernc.org/mathutil v1.1.1/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6E= modernc.org/mathutil v1.2.2/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6E= -modernc.org/mathutil v1.4.0 h1:GCjoRaBew8ECCKINQA2nYjzvufFW9YiEuuB+rQ9bn2E= modernc.org/mathutil v1.4.0/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6E= modernc.org/mathutil v1.4.1 h1:ij3fYGe8zBF4Vu+g0oT7mB06r8sqGWKuJu1yXeR4by8= modernc.org/mathutil v1.4.1/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6E= @@ -227,8 +167,6 @@ modernc.org/memory v1.0.4 h1:utMBrFcpnQDdNsmM6asmyH/FM9TqLPS7XF7otpJmrwM= modernc.org/memory v1.0.4/go.mod h1:nV2OApxradM3/OVbs2/0OsP6nPfakXpi50C7dcoHXlc= modernc.org/opt v0.1.1 h1:/0RX92k9vwVeDXj+Xn23DKp2VJubL7k8qNffND6qn3A= modernc.org/opt v0.1.1/go.mod h1:WdSiB5evDcignE70guQKxYUl14mgWtbClRi5wmkkTX0= -modernc.org/sqlite v1.11.1 h1:SSLaty1rFr9JhVH/Usm2BxzlzaCtf0GhTJ/MJ32GU3Y= -modernc.org/sqlite v1.11.1/go.mod h1:+mhs/P1ONd+6G7hcAs6irwDi/bjTQ7nLW6LHRBsEa3A= modernc.org/sqlite v1.12.0 h1:AMAOgk4CkblRJc6YLKSYtz3pZ6DW5wjQ1uYH/rN7/Kk= modernc.org/sqlite v1.12.0/go.mod h1:ppqJ4cQ+R09YLzl9haEL9AYgj6wX8FcfwDTOI0nYykU= modernc.org/strutil v1.1.1 h1:xv+J1BXY3Opl2ALrBwyfEikFAj8pmqcpnfmuwUwcozs= diff --git a/main.go b/main.go index 55501ef2..38bb2959 100644 --- a/main.go +++ b/main.go @@ -18,7 +18,7 @@ import ( // 娱乐类 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_ai_false" // 服务器监控 - //_ "github.com/FloatTech/ZeroBot-Plugin/plugin_minecraft" + _ "github.com/FloatTech/ZeroBot-Plugin/plugin_minecraft" _ "github.com/FloatTech/ZeroBot-Plugin/plugin_music" // 点歌 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_shindan" // 测定 @@ -29,10 +29,9 @@ import ( // 二次元图片 _ "github.com/FloatTech/ZeroBot-ACGImage" // 随机图片与AI点评 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_image_finder" // 关键字搜图 - - //_ "github.com/FloatTech/ZeroBot-Plugin/plugin_lolicon" // lolicon 随机图片 - _ "github.com/FloatTech/ZeroBot-Plugin/plugin_saucenao" // 以图搜图 - //_ "github.com/FloatTech/ZeroBot-Plugin/plugin_setutime" // 来份涩图 + _ "github.com/FloatTech/ZeroBot-Plugin/plugin_lolicon" // lolicon 随机图片 + _ "github.com/FloatTech/ZeroBot-Plugin/plugin_saucenao" // 以图搜图 + _ "github.com/FloatTech/ZeroBot-Plugin/plugin_setutime" // 来份涩图 // 以下为内置依赖,勿动 zero "github.com/wdvxdr1123/ZeroBot" @@ -71,7 +70,7 @@ func main() { // SuperUsers 某些功能需要主人权限,可通过以下两种方式修改 // []string{}:通过代码写死的方式添加主人账号 // os.Args[1:]:通过命令行参数的方式添加主人账号 - SuperUsers: os.Args[1:], + SuperUsers: append([]string{"12345678", "87654321"}, os.Args[1:]...), Driver: []zero.Driver{ &driver.WSClient{ From 40f1b1c61873b9999bffd3d9b0480b4f3310b2ac Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 17:10:56 +0800 Subject: [PATCH 35/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_diana/bing.go | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/plugin_diana/bing.go b/plugin_diana/bing.go index 1e73dbd7..a316244a 100644 --- a/plugin_diana/bing.go +++ b/plugin_diana/bing.go @@ -1,7 +1,8 @@ /* +Package diana 虚拟偶像女团 A-SOUL 成员嘉然相关 */ -package plugin_diana +package diana import ( "math/rand" @@ -11,6 +12,7 @@ import ( "github.com/wdvxdr1123/ZeroBot/message" ) +/* // 嘉心糖魔怔文 var TEXT = []string{ "我好想做嘉然小姐的狗啊。可是嘉然小姐说她喜欢的是猫,我哭了。我知道既不是狗也不是猫的我为什么要哭的。因为我其实是一只老鼠。我从没奢望嘉然小姐能喜欢自己。我明白的,所有人都喜欢理解余裕上手天才打钱的萌萌的狗狗或者猫猫,没有人会喜欢阴湿带病的老鼠。但我还是问了嘉然小姐:“我能不能做你的狗?”我知道我是注定做不了狗的。但如果她喜欢狗,我就可以一直在身边看着她了,哪怕她怀里抱着的永远都是狗。可是她说喜欢的是猫。她现在还在看着我,还在逗我开心,是因为猫还没有出现,只有我这老鼠每天蹑手蹑脚地从洞里爬出来,远远地和她对视。等她喜欢的猫来了的时候,我就该重新滚回我的洞了吧。但我还是好喜欢她,她能在我还在她身边的时候多看我几眼吗?嘉然小姐说接下来的每个圣诞夜都要和大家一起过。我不知道大家指哪些人。好希望这个集合能够对我做一次胞吞。猫猫还在害怕嘉然小姐。我会去把她爱的猫猫引来的。我知道稍有不慎,我就会葬身猫口。那时候嘉然小姐大概会把我的身体好好地装起来扔到门外吧。那我就成了一包鼠条,嘻嘻。我希望她能把我扔得近一点,因为我还是好喜欢她。会一直喜欢下去的。我的灵魂透过窗户向里面看去,挂着的铃铛在轻轻鸣响,嘉然小姐慵懒地靠在沙发上,表演得非常温顺的橘猫坐在她的肩膀。壁炉的火光照在她的脸庞,我冻僵的心脏在风里微微发烫。", @@ -54,14 +56,14 @@ var TEXT = []string{ "这里除了几个老旧的铁皮棚屋之外,只剩下粗糙的墙体。再没有当年的霓虹灯塔,再没有A-SOUL标志,再没有其他连在一起的建筑了。一切当年的闪耀均不复存在,只剩下铁皮棚屋上斑驳褪色的女子团伙宣传画。贝极星透过雾气在闪闪发光,月亮也升到了空中,因而夜晚并不显得黑暗。我依稀能辨别出枝江大厦的每一个部分,哪儿曾是夜谈会上扫地机停留的地方,哪儿曾是大门,哪儿曾放着螺蛳粉味薯片。我一一回忆怀念,忽然看见一个孤独的身影,这个身影迟疑了一下,同时我也惊叫了出来。“嘉然小姐!”“我奇怪你怎么还认得出我,我完全变了。”确实她的青春艳丽已经消逝,然而她那难以言表的端庄华丽,她那难以言表的迷人妩媚却依旧当年。所有这些美的诱惑,从前我都见过,而我以前所没有见过的是她那一对眼睛,从前她的双眸总闪着傲气,如今却闪着凄凉酸楚的光。我们坐在附近的一张长椅上,我说道:“多少年如流云般过去,嘉然小姐,你时常回到这里吗?”“我一直没有回来过。”“我也没有。”月亮开始上升,邀游夜空,我脑海中出现了贝拉注视着白色月亮的宁静目光。嘉然小姐终于打破了我们之间的沉默。“我一直在希望有一天能回来看看,可是各种各样的情况使我不能回来。”月光和她的泪珠融合在一起,她没有意识到我已经察觉,想抑制住自己的情感,以平静的语气说道,“我时常想到你。”“真的?”“特别是近些日子,我更常想到你。虽然我生活中有一段很长的艰苦日子,但是我不会去想。自从我个人的情况不如意后,这些口忆就不得不在我心头占一席之地。”“你永远在我的心里。”我答道。我们又一次沉默无言,直到她打破沉寂。“我没有想到,”嘉然说道,“我到这里来和故地告别,竟然又是和你告别,我感到很高兴。”“嘉然小姐,和我又一次分别,你高兴吗?可是对我来说,上次分别时的悲伤和痛苦永远地萦绕在我的记忆之中。”“可是,你上次不是对我说过,”嘉然答道,“但愿圣嘉然保佑你。你上次能这么对我说,你现在也能毫不犹豫地这样对我说,但我并不是什么圣嘉然。多年来的痛苦让我受尽折磨,但是希望你像从前一样体谅我,善待我,并且告诉我,我俩仍是朋友。”“我俩仍是朋友。”我说着站起身,并俯身扶她从长椅上站了起来。“我们虽然分离,但愿情意长存。”嘉然说道。我把她的手握在自己手中,一同走出这片废墟,夜雾也正开始消散。一片广阔的静寂沉浸在月色之中,似乎向我表明,我和她将永远一起,不再分离。", "我和她已经冷战很久了,她画她的画,我看我的报,养我的花。我们中间隔着薄薄一层栅栏,却不曾互相道过早安晚安,我祈祷,有一位天使来拯救我们岌岌可危的爱情。羽毛如雪洁白,天生气质优雅的一只鹅,他是天使派来的吗,我想在它把我的拖鞋叼走,把衣服拖得到处都是的时候,我的心里开始怀疑自己祈祷的虔诚。淘气的小鹅它把我们的花园弄得一团糟,我弄碎了她的花瓶,她剪断了我的花朵,脏衣服满地都是,但是啊,虽然是互相埋怨,但好久没和她说过话了,虽然经历岁月的痕迹,她的脸也不再年轻充满活力,但她还是像从前那样,吵架笑出来的话,不就无法进行下去了吗。“我们和好吧”“好”我和她携手把隔离两边花园的栅栏拆了,牵着手目送那只纯白的小天使离开。原来你真的是天使派来拯救我的呀,小鹅。", "我一边办公,一边看着在第五人格里扮演求生者重启一台又一台发电机成功逃出生天的gamer向晚,满怀羡慕。夸张点说,嫉妒得我眼睛比手里的烟头还红。告诉你们一个秘密,其实我也是求生者,你们也是。电话铃突然响起,我一扫号码腰立刻矮下半截:“喂,经理,是我是我,那个设计您不满意我可以改嘛,全部改掉?好的好的。”我颤颤巍巍地撂下电话,一边重新修改产品一边继续沉思。你看:上司和我、甲方和乙方、跑的和抓的、鼠和猫、求生者与妖怪、某种场合下的S和M,这个世界上总要有个矛盾,矛盾当事人总要以这种形式体现出来。而我似乎总是处在被动的一方(当然也没人让我选过),并对这种境遇见怪不怪。我有时会觉得SM其实是一种相当和谐的关系,因为至少他们偶尔会爱上彼此,而上司决不会对我有半个好脸色。而且我听闻SM会在每场游戏开始前设定一个安全词,放游戏里叫投降,这可以让求生者在感到极度痛苦时结束游戏,避免不必要的损失。这简直令我嫉妒得发狂,我在现实生活折磨的二十年里可从来没有安全词!岂止没有安全词,我甚至都不能像游戏里求生者受伤那样大声哀嚎。因为现实是个面子社会,里子流血面子总得兜住。那怕你的心已经被戳得千疮百孔想花洒那样往外喷番茄汁,你也得对同事家人笑一笑。失去尚可,失败无赦,一旦痛呼出来,就彻底失败了。你以为“别人家的小孩”成绩优异自律自强,可能他内心已经被现实整得口球都带上了;你以为职场同事一个个西装革履,可能拉开就是一身龟甲缚。电话再次响起,我接起电话:“经理,什么,已经有人完成了?不采用了?哦,好的好的,没关系没关系。”妈的,为什么我一想到现实里并不是向晚玩的游戏那样四个人同心同德逃出生天,而是筋疲力竭地互相滴蜡油来竞争一个生存名额,我就止不住地流下泪来。", -} +}*/ func init() { // 随机发送一篇上面的小作文 zero.OnFullMatch("小作文", zero.OnlyToMe). Handle(func(ctx *zero.Ctx) { rand.Seed(time.Now().UnixNano()) - ctx.SendChain(message.Text(TEXT[rand.Intn(len(TEXT))])) + ctx.SendChain(message.Text(ARRAY[rand.Intn(len(ARRAY))])) }) // 逆天 @@ -69,4 +71,9 @@ func init() { Handle(func(ctx *zero.Ctx) { ctx.Send("贝拉抽我🥵嘉然骑在我背上🥵晚晚踩我🥵乃琳坐在王座是用看垃圾的眼神看我🥵🥵珈乐踢我🥵🥵,把我眼睛蒙住然后五只脚一起踩我🥵还让我猜脚是谁的,猜错了给我劈眼一铁棍🥵​") }) + // 增加小作文 + zero.OnRegex(`^教你一篇小作文(.*)$`, zero.AdminPermission). + Handle(func(ctx *zero.Ctx) { + addText(ctx.State["regex_matched"].([]string)[1]) + }) } From fd64016e198a0de027207ea66e983faf8e8d94fa Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 17:11:03 +0800 Subject: [PATCH 36/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 3 +- go.mod | 2 + go.sum | 12 ++ plugin_ai_false/ai_false.go | 6 +- plugin_atri/atri.go | 66 +++---- plugin_bilibili/fansDaily.go | 6 +- plugin_bilibili/info.go | 7 +- plugin_bilibili/live_info.go | 2 +- plugin_chat/chat.go | 4 +- plugin_diana/text.go | 64 +++++++ plugin_diana/text.pb.go | 326 +++++++++++++++++++++++++++++++++ plugin_diana/text.proto | 6 + plugin_diana/zhiwang.go | 14 +- plugin_github/repo_searcher.go | 3 +- plugin_image_finder/keyword.go | 14 +- plugin_lolicon/lolicon.go | 17 +- plugin_manager/manager.go | 2 +- plugin_minecraft/info.go | 7 +- plugin_minecraft/manager.go | 7 +- plugin_music/selecter.go | 3 +- plugin_runcode/code_runner.go | 3 +- plugin_saucenao/searcher.go | 3 +- plugin_setutime/setu_geter.go | 68 +++---- plugin_setutime/sqlite.go | 26 +-- plugin_shindan/shindan.go | 3 +- 25 files changed, 548 insertions(+), 126 deletions(-) create mode 100644 plugin_diana/text.go create mode 100644 plugin_diana/text.pb.go create mode 100644 plugin_diana/text.proto diff --git a/.gitignore b/.gitignore index e5aa424d..601f1673 100644 --- a/.gitignore +++ b/.gitignore @@ -2,4 +2,5 @@ data/SetuTime/cache data/SetuTime/search data/manager .idea/ -.DS_Store \ No newline at end of file +.DS_Store +.vscode \ No newline at end of file diff --git a/go.mod b/go.mod index acd5d750..405ee98b 100644 --- a/go.mod +++ b/go.mod @@ -7,6 +7,7 @@ require ( github.com/FloatTech/ZeroBot-ACGImage v1.5.5 github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4 github.com/StackExchange/wmi v1.2.1 // indirect + github.com/golang/protobuf v1.5.2 github.com/robfig/cron v1.2.0 github.com/shirou/gopsutil v3.21.7+incompatible github.com/sirupsen/logrus v1.8.1 @@ -17,5 +18,6 @@ require ( github.com/wdvxdr1123/ZeroBot v1.2.2 golang.org/x/text v0.3.6 // indirect golang.org/x/tools v0.1.5 // indirect + google.golang.org/protobuf v1.27.1 // indirect modernc.org/sqlite v1.12.0 ) diff --git a/go.sum b/go.sum index c47fe794..c1ac735d 100644 --- a/go.sum +++ b/go.sum @@ -20,6 +20,8 @@ github.com/dustin/go-humanize v1.0.0/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25Kn github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo= github.com/go-ole/go-ole v1.2.5 h1:t4MGB5xEDZvXI+0rMjjsfBsD7yAgp/s9ZDkL1JndXwY= github.com/go-ole/go-ole v1.2.5/go.mod h1:pprOEPIfldk/42T2oK7lQ4v4JSDwmV0As9GaiUsvbm0= +github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q= +github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q= github.com/golang/groupcache v0.0.0-20200121045136-8c9f03a8e57e h1:1r7pUrabqp18hOBcwBwiTsbnFeTZHV9eER/QT5JVZxY= github.com/golang/groupcache v0.0.0-20200121045136-8c9f03a8e57e/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= github.com/golang/protobuf v1.2.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= @@ -38,6 +40,8 @@ github.com/json-iterator/go v1.1.11 h1:uVUAXhF2To8cbw/3xN3pxj6kk7TYKs98NIrTqPlMW github.com/json-iterator/go v1.1.11/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51 h1:Z9n2FFNUXsshfwJMBgNA0RU6/i7WVaAegv3PtuIHPMs= github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51/go.mod h1:CzGEWj7cYgsdH8dAjBGEr58BoE7ScuLd+fwFZ44+/x8= +github.com/kisielk/errcheck v1.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI2bnpBCr8= +github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck= github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= github.com/mattn/go-isatty v0.0.12 h1:wuysRhFDzyxgEmMf5xjvJ2M9dZoWAXNNr5LSBS7uHXY= github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Kysco4FUpU= @@ -85,23 +89,27 @@ github.com/tklauser/numcpus v0.2.3 h1:nQ0QYpiritP6ViFhrKYsiv6VVxOpum2Gks5GhnJbS/ github.com/tklauser/numcpus v0.2.3/go.mod h1:vpEPS/JC+oZGGQ/My/vJnNsvMDQL6PwOqt8dsCw5j+E= github.com/wdvxdr1123/ZeroBot v1.2.2 h1:BKEy3l80BMrQWpFWaII0AfFMyf9bqrB0TxfWhTdoV58= github.com/wdvxdr1123/ZeroBot v1.2.2/go.mod h1:83nHtG8V5TAxPwH/LCDxLpZk4khIgs29dkr5TBWf7fc= +github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= github.com/yuin/goldmark v1.3.5/go.mod h1:mwnBkeHKe2W/ZEtQ+71ViKU8L12m81fl3OWwC1Zlc8k= golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= +golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/mod v0.4.2 h1:Gz96sIWK3OalVv/I/qNygP42zyoKp3xptRVCWRFEBvo= golang.org/x/mod v0.4.2/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/net v0.0.0-20180906233101-161cd47e91fd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= +golang.org/x/net v0.0.0-20200226121028-0de0cce0169b/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20200421231249-e086a090c8fd/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4 h1:4nGaVu0QrbjT/AK2PRLuQfQuh6DJve+pELhqTdAj3x0= golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4/go.mod h1:p54w0d4576C0XHj96bSt6lcn1PtDYWL6XObtHCRCNQM= golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= @@ -127,7 +135,9 @@ golang.org/x/text v0.3.6 h1:aRYxNxv6iGQlyVaZmk6ZgYEDa+Jg18DxebPSrd6bg1M= golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= +golang.org/x/tools v0.0.0-20200619180055-7c47624df98f/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= golang.org/x/tools v0.0.0-20201124115921-2c860bdd6e78/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= +golang.org/x/tools v0.0.0-20210106214847-113979e3529a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= golang.org/x/tools v0.1.5 h1:ouewzE6p+/VEB31YYnTbEJdi8pFqKp4P4n85vwo3DHA= golang.org/x/tools v0.1.5/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= @@ -138,6 +148,8 @@ golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8T google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw= google.golang.org/protobuf v1.26.0 h1:bxAC2xTBsZGibn2RTntX0oH50xLsqy1OxA9tTL3p/lk= google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc= +google.golang.org/protobuf v1.27.1 h1:SnqbnDw1V7RiZcXPx5MEeqPv2s79L9i7BJUlG/+RurQ= +google.golang.org/protobuf v1.27.1/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/fsnotify.v1 v1.4.7/go.mod h1:Tz8NjZHkW78fSQdbUxIjBTcgA1z1m8ZHf0WmKUhAMys= gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7/go.mod h1:dt/ZhP58zS4L8KSrWDmTeBkI65Dw0HsyUHuEVlX15mw= diff --git a/plugin_ai_false/ai_false.go b/plugin_ai_false/ai_false.go index 6d370f7d..15d907ab 100644 --- a/plugin_ai_false/ai_false.go +++ b/plugin_ai_false/ai_false.go @@ -1,7 +1,5 @@ -/* -暂时只有服务器监控 -*/ -package plugin_ai_false +// Package aifalse 暂时只有服务器监控 +package aifalse import ( "math" diff --git a/plugin_atri/atri.go b/plugin_atri/atri.go index fd11ead9..feb232e6 100644 --- a/plugin_atri/atri.go +++ b/plugin_atri/atri.go @@ -1,7 +1,9 @@ -// Package atri -// 本文件基于 https://github.com/Kyomotoi/ATRI -// 为 Golang 移植版,语料、素材均来自上述项目 -// 本项目遵守 AGPL v3 协议进行开源 +/* +Package atri +本文件基于 https://github.com/Kyomotoi/ATRI +为 Golang 移植版,语料、素材均来自上述项目 +本项目遵守 AGPL v3 协议进行开源 +*/ package atri import ( @@ -14,25 +16,25 @@ import ( var ( // ATRI 所有命令的优先级 - PRIO = -1 + prio = -1 // ATRI 表情的 GitHub 镜像位置 - RES = "https://raw.dihe.moe/Yiwen-Chan/ZeroBot-Plugin/master/plugin_atri/" + res = "https://raw.dihe.moe/Yiwen-Chan/ZeroBot-Plugin/master/plugin_atri/" // ATRI 的总开关 - ENABLE = true + enable = true ) func init() { // 插件主体 - zero.OnFullMatch("ATRI醒醒", zero.AdminPermission).SetBlock(true).SetPriority(PRIO). + zero.OnFullMatch("ATRI醒醒", zero.AdminPermission).SetBlock(true).SetPriority(prio). Handle(func(ctx *zero.Ctx) { - ENABLE = true + enable = true ctx.SendChain(randText("嗯呜呜……夏生先生……?")) }) - zero.OnFullMatch("ATRI睡吧", zero.AdminPermission).SetBlock(true).SetPriority(PRIO). + zero.OnFullMatch("ATRI睡吧", zero.AdminPermission).SetBlock(true).SetPriority(prio). Handle(func(ctx *zero.Ctx) { - ENABLE = false + enable = false ctx.SendChain(randText("Zzz……Zzz……")) }) - zero.OnFullMatch("萝卜子", AtriSwitch(), AtriSleep()).SetBlock(true).SetPriority(PRIO). + zero.OnFullMatch("萝卜子", atriSwitch(), atriSleep()).SetBlock(true).SetPriority(prio). Handle(func(ctx *zero.Ctx) { switch rand.Intn(2) { case 0: @@ -41,17 +43,17 @@ func init() { // 插件主体 ctx.SendChain(randRecord("RocketPunch.amr")) } }) - zero.OnKeywordGroup([]string{"喜欢", "爱你", "爱", "suki", "daisuki", "すき", "好き", "贴贴", "老婆", "亲一个", "mua"}, AtriSwitch(), AtriSleep(), zero.OnlyToMe).SetBlock(true).SetPriority(PRIO). + zero.OnKeywordGroup([]string{"喜欢", "爱你", "爱", "suki", "daisuki", "すき", "好き", "贴贴", "老婆", "亲一个", "mua"}, atriSwitch(), atriSleep(), zero.OnlyToMe).SetBlock(true).SetPriority(prio). Handle(func(ctx *zero.Ctx) { if rand.Intn(10) == 0 { ctx.SendChain(randImage("SUKI.jpg", "SUKI1.jpg", "SUKI2.png")) } }) - zero.OnKeywordGroup([]string{"草你妈", "操你妈", "脑瘫", "废柴", "fw", "five", "废物", "战斗", "爬", "爪巴", "sb", "SB", "傻B"}, AtriSwitch(), AtriSleep(), zero.OnlyToMe).SetBlock(true).SetPriority(PRIO - 1). + zero.OnKeywordGroup([]string{"草你妈", "操你妈", "脑瘫", "废柴", "fw", "five", "废物", "战斗", "爬", "爪巴", "sb", "SB", "傻B"}, atriSwitch(), atriSleep(), zero.OnlyToMe).SetBlock(true).SetPriority(prio - 1). Handle(func(ctx *zero.Ctx) { ctx.SendChain(randImage("FN.jpg", "WQ.jpg", "WQ1.jpg")) }) - zero.OnFullMatchGroup([]string{"早安", "早哇", "早上好", "ohayo", "哦哈哟", "お早う"}, AtriSwitch()).SetBlock(true).SetPriority(PRIO). + zero.OnFullMatchGroup([]string{"早安", "早哇", "早上好", "ohayo", "哦哈哟", "お早う"}, atriSwitch()).SetBlock(true).SetPriority(prio). Handle(func(ctx *zero.Ctx) { now := time.Now().Hour() switch { @@ -90,7 +92,7 @@ func init() { // 插件主体 )) } }) - zero.OnFullMatchGroup([]string{"中午好", "午安"}, AtriSwitch()).SetBlock(true).SetPriority(PRIO). + zero.OnFullMatchGroup([]string{"中午好", "午安"}, atriSwitch()).SetBlock(true).SetPriority(prio). Handle(func(ctx *zero.Ctx) { now := time.Now().Hour() if now > 11 && now < 15 { // 中午 @@ -102,7 +104,7 @@ func init() { // 插件主体 )) } }) - zero.OnFullMatchGroup([]string{"晚安", "oyasuminasai", "おやすみなさい"}, AtriSwitch()).SetBlock(true).SetPriority(PRIO). + zero.OnFullMatchGroup([]string{"晚安", "oyasuminasai", "おやすみなさい"}, atriSwitch()).SetBlock(true).SetPriority(prio). Handle(func(ctx *zero.Ctx) { now := time.Now().Hour() switch { @@ -144,7 +146,7 @@ func init() { // 插件主体 )) } }) - zero.OnKeywordGroup([]string{"高性能", "太棒了", "すごい", "sugoi", "斯国一", "よかった"}, AtriSwitch(), AtriSleep(), zero.OnlyToMe).SetBlock(true).SetPriority(PRIO). + zero.OnKeywordGroup([]string{"高性能", "太棒了", "すごい", "sugoi", "斯国一", "よかった"}, atriSwitch(), atriSleep(), zero.OnlyToMe).SetBlock(true).SetPriority(prio). Handle(func(ctx *zero.Ctx) { ctx.SendChain(randText( "当然,我是高性能的嘛~!", @@ -164,7 +166,7 @@ func init() { // 插件主体 "呣......我的高性能,毫无遗憾地施展出来了......", )) }) - zero.OnKeywordGroup([]string{"没事", "没关系", "大丈夫", "还好", "不要紧", "没出大问题", "没伤到哪"}, AtriSwitch(), AtriSleep(), zero.OnlyToMe).SetBlock(true).SetPriority(PRIO). + zero.OnKeywordGroup([]string{"没事", "没关系", "大丈夫", "还好", "不要紧", "没出大问题", "没伤到哪"}, atriSwitch(), atriSleep(), zero.OnlyToMe).SetBlock(true).SetPriority(prio). Handle(func(ctx *zero.Ctx) { ctx.SendChain(randText( "当然,我是高性能的嘛~!", @@ -178,23 +180,23 @@ func init() { // 插件主体 )) }) - zero.OnKeywordGroup([]string{"好吗", "是吗", "行不行", "能不能", "可不可以"}, AtriSwitch(), AtriSleep()).SetBlock(true).SetPriority(PRIO). + zero.OnKeywordGroup([]string{"好吗", "是吗", "行不行", "能不能", "可不可以"}, atriSwitch(), atriSleep()).SetBlock(true).SetPriority(prio). Handle(func(ctx *zero.Ctx) { if rand.Intn(2) == 0 { ctx.SendChain(randImage("YES.png", "NO.jpg")) } }) - zero.OnFullMatchGroup([]string{"啊这"}, AtriSwitch(), AtriSleep()).SetBlock(true).SetPriority(PRIO). + zero.OnFullMatchGroup([]string{"啊这"}, atriSwitch(), atriSleep()).SetBlock(true).SetPriority(prio). Handle(func(ctx *zero.Ctx) { if rand.Intn(2) == 0 { ctx.SendChain(randImage("AZ.jpg", "AZ1.jpg")) } }) - zero.OnFullMatchGroup([]string{"我好了"}, AtriSwitch(), AtriSleep()).SetBlock(true).SetPriority(PRIO). + zero.OnFullMatchGroup([]string{"我好了"}, atriSwitch(), atriSleep()).SetBlock(true).SetPriority(prio). Handle(func(ctx *zero.Ctx) { ctx.SendChain(randText("不许好!", "憋回去!")) }) - zero.OnFullMatchGroup([]string{"?", "?", "¿"}, AtriSwitch(), AtriSleep()).SetBlock(true).SetPriority(PRIO). + zero.OnFullMatchGroup([]string{"?", "?", "¿"}, atriSwitch(), atriSleep()).SetBlock(true).SetPriority(prio). Handle(func(ctx *zero.Ctx) { switch rand.Intn(5) { case 0: @@ -203,7 +205,7 @@ func init() { // 插件主体 ctx.SendChain(randImage("WH.jpg", "WH1.jpg", "WH2.jpg", "WH3.jpg")) } }) - zero.OnKeyword("离谱", AtriSwitch(), AtriSleep()).SetBlock(true).SetPriority(PRIO). + zero.OnKeyword("离谱", atriSwitch(), atriSleep()).SetBlock(true).SetPriority(prio). Handle(func(ctx *zero.Ctx) { switch rand.Intn(5) { case 0: @@ -212,7 +214,7 @@ func init() { // 插件主体 ctx.SendChain(randImage("WH.jpg")) } }) - zero.OnKeyword("答应我", AtriSwitch(), AtriSleep(), zero.OnlyToMe).SetBlock(true).SetPriority(PRIO). + zero.OnKeyword("答应我", atriSwitch(), atriSleep(), zero.OnlyToMe).SetBlock(true).SetPriority(prio). Handle(func(ctx *zero.Ctx) { ctx.SendChain(randText("我无法回应你的请求")) }) @@ -225,23 +227,23 @@ func randText(text ...string) message.MessageSegment { func randImage(file ...string) message.MessageSegment { length := len(file) - return message.Image(RES + file[rand.Intn(length)]) + return message.Image(res + file[rand.Intn(length)]) } func randRecord(file ...string) message.MessageSegment { length := len(file) - return message.Record(RES + file[rand.Intn(length)]) + return message.Record(res + file[rand.Intn(length)]) } -// AtriSwitch 控制 ATRI 的开关 -func AtriSwitch() zero.Rule { +// atriSwitch 控制 ATRI 的开关 +func atriSwitch() zero.Rule { return func(ctx *zero.Ctx) bool { - return ENABLE + return enable } } -// AtriSleep 凌晨0点到6点,ATRI 在睡觉,不回应任何请求 -func AtriSleep() zero.Rule { +// atriSleep 凌晨0点到6点,ATRI 在睡觉,不回应任何请求 +func atriSleep() zero.Rule { return func(ctx *zero.Ctx) bool { if now := time.Now().Hour(); now >= 1 && now < 6 { return false diff --git a/plugin_bilibili/fansDaily.go b/plugin_bilibili/fansDaily.go index ec7ba86f..7122a96a 100644 --- a/plugin_bilibili/fansDaily.go +++ b/plugin_bilibili/fansDaily.go @@ -1,4 +1,4 @@ -package plugin_bilibili +package bilibili import ( "encoding/json" @@ -25,12 +25,12 @@ type follower struct { func init() { zero.OnFullMatch("/开启粉丝日报", zero.AdminPermission). Handle(func(ctx *zero.Ctx) { - FansDaily(130591566) // 群号传进去给下面发信息的函数 + fansDaily(130591566) // 群号传进去给下面发信息的函数 }) } // 定时任务每天晚上最后2分钟执行一次 -func FansDaily(groupID int64) { +func fansDaily(groupID int64) { c := cron.New() _ = c.AddFunc("0 58 23 * * ?", func() { fansData(groupID) }) c.Start() diff --git a/plugin_bilibili/info.go b/plugin_bilibili/info.go index fd3b7042..5741bd3f 100644 --- a/plugin_bilibili/info.go +++ b/plugin_bilibili/info.go @@ -1,11 +1,12 @@ -package plugin_bilibili +package bilibili import ( + "io/ioutil" + "net/http" + "github.com/tidwall/gjson" zero "github.com/wdvxdr1123/ZeroBot" "github.com/wdvxdr1123/ZeroBot/message" - "io/ioutil" - "net/http" ) // 查成分的 diff --git a/plugin_bilibili/live_info.go b/plugin_bilibili/live_info.go index 60845cb6..0c94869d 100644 --- a/plugin_bilibili/live_info.go +++ b/plugin_bilibili/live_info.go @@ -1,4 +1,4 @@ -package plugin_bilibili +package bilibili import ( "errors" diff --git a/plugin_chat/chat.go b/plugin_chat/chat.go index 38d7489f..3164af84 100644 --- a/plugin_chat/chat.go +++ b/plugin_chat/chat.go @@ -1,8 +1,8 @@ /* -Package plugin_chat +Package chat 对话插件 example */ -package plugin_chat +package chat import ( "math/rand" diff --git a/plugin_diana/text.go b/plugin_diana/text.go new file mode 100644 index 00000000..c9cd2ac7 --- /dev/null +++ b/plugin_diana/text.go @@ -0,0 +1,64 @@ +package diana + +import ( + "io" + "os" + "time" +) + +const ( + datapath = "data/Diana" + pbfile = datapath + "/text.pb" +) + +var ( + compo Composition + ARRAY []string +) + +func init() { + go func() { + time.Sleep(time.Second) + err := os.MkdirAll(datapath, 0755) + if err != nil { + panic(err) + } + loadText() + ARRAY = compo.Array + }() +} + +func loadText() { + if _, err := os.Stat(pbfile); err == nil || os.IsExist(err) { + f, err := os.Open(pbfile) + if err == nil { + data, err1 := io.ReadAll(f) + if err1 == nil { + if len(data) > 0 { + compo.Unmarshal(data) + } + } + } + } +} + +func addText(txt string) error { + if txt != "" { + ARRAY = append(ARRAY, txt) + data, err := compo.Marshal() + if err == nil { + if _, err := os.Stat(datapath); err == nil || os.IsExist(err) { + f, err1 := os.OpenFile(pbfile, os.O_WRONLY|os.O_TRUNC|os.O_CREATE, 0644) + if err1 != nil { + return err1 + } else { + defer f.Close() + _, err2 := f.Write(data) + return err2 + } + } + } + return err + } + return nil +} diff --git a/plugin_diana/text.pb.go b/plugin_diana/text.pb.go new file mode 100644 index 00000000..dedafd23 --- /dev/null +++ b/plugin_diana/text.pb.go @@ -0,0 +1,326 @@ +// Code generated by protoc-gen-gogo. DO NOT EDIT. +// source: text.proto + +package diana + +import ( + fmt "fmt" + proto "github.com/golang/protobuf/proto" + io "io" + math "math" + math_bits "math/bits" +) + +// Reference imports to suppress errors if they are not otherwise used. +var _ = proto.Marshal +var _ = fmt.Errorf +var _ = math.Inf + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the proto package it is being compiled against. +// A compilation error at this line likely means your copy of the +// proto package needs to be updated. +const _ = proto.ProtoPackageIsVersion3 // please upgrade the proto package + +type Composition struct { + Array []string `protobuf:"bytes,1,rep,name=array,proto3" json:"array,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *Composition) Reset() { *m = Composition{} } +func (m *Composition) String() string { return proto.CompactTextString(m) } +func (*Composition) ProtoMessage() {} +func (*Composition) Descriptor() ([]byte, []int) { + return fileDescriptor_a8e73d1ce47f9297, []int{0} +} +func (m *Composition) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *Composition) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_Composition.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *Composition) XXX_Merge(src proto.Message) { + xxx_messageInfo_Composition.Merge(m, src) +} +func (m *Composition) XXX_Size() int { + return m.Size() +} +func (m *Composition) XXX_DiscardUnknown() { + xxx_messageInfo_Composition.DiscardUnknown(m) +} + +var xxx_messageInfo_Composition proto.InternalMessageInfo + +func (m *Composition) GetArray() []string { + if m != nil { + return m.Array + } + return nil +} + +func init() { + proto.RegisterType((*Composition)(nil), "diana.composition") +} + +func init() { proto.RegisterFile("text.proto", fileDescriptor_a8e73d1ce47f9297) } + +var fileDescriptor_a8e73d1ce47f9297 = []byte{ + // 100 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0xe2, 0x2a, 0x49, 0xad, 0x28, + 0xd1, 0x2b, 0x28, 0xca, 0x2f, 0xc9, 0x17, 0x62, 0x4d, 0xc9, 0x4c, 0xcc, 0x4b, 0x54, 0x52, 0xe6, + 0xe2, 0x4e, 0xce, 0xcf, 0x2d, 0xc8, 0x2f, 0xce, 0x2c, 0xc9, 0xcc, 0xcf, 0x13, 0x12, 0xe1, 0x62, + 0x4d, 0x2c, 0x2a, 0x4a, 0xac, 0x94, 0x60, 0x54, 0x60, 0xd6, 0xe0, 0x0c, 0x82, 0x70, 0x9c, 0x04, + 0x4e, 0x3c, 0x92, 0x63, 0xbc, 0xf0, 0x48, 0x8e, 0xf1, 0xc1, 0x23, 0x39, 0xc6, 0x19, 0x8f, 0xe5, + 0x18, 0x92, 0xd8, 0xc0, 0x86, 0x18, 0x03, 0x02, 0x00, 0x00, 0xff, 0xff, 0x22, 0x35, 0x44, 0xcb, + 0x52, 0x00, 0x00, 0x00, +} + +func (m *Composition) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *Composition) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *Composition) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.Array) > 0 { + for iNdEx := len(m.Array) - 1; iNdEx >= 0; iNdEx-- { + i -= len(m.Array[iNdEx]) + copy(dAtA[i:], m.Array[iNdEx]) + i = encodeVarintText(dAtA, i, uint64(len(m.Array[iNdEx]))) + i-- + dAtA[i] = 0xa + } + } + return len(dAtA) - i, nil +} + +func encodeVarintText(dAtA []byte, offset int, v uint64) int { + offset -= sovText(v) + base := offset + for v >= 1<<7 { + dAtA[offset] = uint8(v&0x7f | 0x80) + v >>= 7 + offset++ + } + dAtA[offset] = uint8(v) + return base +} +func (m *Composition) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if len(m.Array) > 0 { + for _, s := range m.Array { + l = len(s) + n += 1 + l + sovText(uint64(l)) + } + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func sovText(x uint64) (n int) { + return (math_bits.Len64(x|1) + 6) / 7 +} +func sozText(x uint64) (n int) { + return sovText(uint64((x << 1) ^ uint64((int64(x) >> 63)))) +} +func (m *Composition) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowText + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: composition: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: composition: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Array", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowText + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthText + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthText + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Array = append(m.Array, string(dAtA[iNdEx:postIndex])) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipText(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthText + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func skipText(dAtA []byte) (n int, err error) { + l := len(dAtA) + iNdEx := 0 + depth := 0 + for iNdEx < l { + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowText + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= (uint64(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + wireType := int(wire & 0x7) + switch wireType { + case 0: + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowText + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + iNdEx++ + if dAtA[iNdEx-1] < 0x80 { + break + } + } + case 1: + iNdEx += 8 + case 2: + var length int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowText + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + length |= (int(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + if length < 0 { + return 0, ErrInvalidLengthText + } + iNdEx += length + case 3: + depth++ + case 4: + if depth == 0 { + return 0, ErrUnexpectedEndOfGroupText + } + depth-- + case 5: + iNdEx += 4 + default: + return 0, fmt.Errorf("proto: illegal wireType %d", wireType) + } + if iNdEx < 0 { + return 0, ErrInvalidLengthText + } + if depth == 0 { + return iNdEx, nil + } + } + return 0, io.ErrUnexpectedEOF +} + +var ( + ErrInvalidLengthText = fmt.Errorf("proto: negative length found during unmarshaling") + ErrIntOverflowText = fmt.Errorf("proto: integer overflow") + ErrUnexpectedEndOfGroupText = fmt.Errorf("proto: unexpected end of group") +) diff --git a/plugin_diana/text.proto b/plugin_diana/text.proto new file mode 100644 index 00000000..af735c4a --- /dev/null +++ b/plugin_diana/text.proto @@ -0,0 +1,6 @@ +syntax = "proto3"; +package diana; + +message composition { + repeated string array = 1; +} diff --git a/plugin_diana/zhiwang.go b/plugin_diana/zhiwang.go index 434ad8ce..88daf72d 100644 --- a/plugin_diana/zhiwang.go +++ b/plugin_diana/zhiwang.go @@ -1,16 +1,18 @@ -package plugin_diana +package diana import ( "bytes" "encoding/json" - "github.com/wdvxdr1123/ZeroBot/message" "math" "strconv" "time" - zero "github.com/wdvxdr1123/ZeroBot" + "github.com/wdvxdr1123/ZeroBot/message" + "net/http" "strings" + + zero "github.com/wdvxdr1123/ZeroBot" ) type zhiwang struct { @@ -26,7 +28,7 @@ type zhiwang struct { // 小作文查重: 回复要查的消息 查重 func init() { - zero.OnMessage(FullMatchText("查重")). + zero.OnMessage(fullMatchText("查重")). Handle(func(ctx *zero.Ctx) { msg := ctx.Event.Message if msg[0].Type == "reply" { @@ -88,7 +90,7 @@ func zhiwangapi(Text string) *zhiwang { return result } -func FullMatchText(src ...string) zero.Rule { +func fullMatchText(src ...string) zero.Rule { return func(ctx *zero.Ctx) bool { msg := ctx.Event.Message for _, elem := range msg { @@ -106,4 +108,4 @@ func FullMatchText(src ...string) zero.Rule { } return false } -} \ No newline at end of file +} diff --git a/plugin_github/repo_searcher.go b/plugin_github/repo_searcher.go index 511be65b..f2a3f4c8 100644 --- a/plugin_github/repo_searcher.go +++ b/plugin_github/repo_searcher.go @@ -1,7 +1,8 @@ /* +Plugin github GitHub 仓库搜索 */ -package plugin_github +package github import ( "errors" diff --git a/plugin_image_finder/keyword.go b/plugin_image_finder/keyword.go index 5cdf5013..15f7d572 100644 --- a/plugin_image_finder/keyword.go +++ b/plugin_image_finder/keyword.go @@ -1,4 +1,4 @@ -package plugin_image_finder +package imagefinder import ( "encoding/json" @@ -11,7 +11,7 @@ import ( "github.com/wdvxdr1123/ZeroBot/message" ) -type AutoGenerated struct { +type resultjson struct { Illusts []struct { ID int `json:"id"` Title string `json:"title"` @@ -63,7 +63,7 @@ func init() { keyword := ctx.State["regex_matched"].([]string)[1] soutujson := soutuapi(keyword) pom1 := "https://i.pixiv.cat" - rannum := Suiji() + rannum := rand_int() pom2 := soutujson.Illusts[rannum].ImageUrls.Large[19:] ctx.SendChain(message.Image(pom1 + pom2)) }) @@ -71,7 +71,7 @@ func init() { } // soutuapi 请求api -func soutuapi(keyword string) *AutoGenerated { +func soutuapi(keyword string) *resultjson { url := "https://api.pixivel.moe/pixiv?type=search&page=0&mode=partial_match_for_tags&word=" + keyword method := "GET" @@ -90,15 +90,15 @@ func soutuapi(keyword string) *AutoGenerated { } defer res.Body.Close() - result := &AutoGenerated{} + result := &resultjson{} if err := json.NewDecoder(res.Body).Decode(result); err != nil { panic(err) } return result } -// Suiji 从json里的30条数据中随机获取一条返回 -func Suiji() int { +// rand_int 从json里的30条数据中随机获取一条返回 +func rand_int() int { rand.Seed(time.Now().UnixNano()) return rand.Intn(30) } diff --git a/plugin_lolicon/lolicon.go b/plugin_lolicon/lolicon.go index 22c0d6ea..2184396a 100644 --- a/plugin_lolicon/lolicon.go +++ b/plugin_lolicon/lolicon.go @@ -1,7 +1,8 @@ /* +Package lolicon 基于 https://api.lolicon.app 随机图片 */ -package plugin_lolicon +package lolicon import ( "io/ioutil" @@ -14,20 +15,20 @@ import ( ) const ( - API = "https://api.lolicon.app/setu/v2" - CAP = 10 + api = "https://api.lolicon.app/setu/v2" + capacity = 10 ) var ( - QUEUE = make(chan string, CAP) + queue = make(chan string, capacity) ) func init() { zero.OnFullMatch("来份萝莉"). Handle(func(ctx *zero.Ctx) { go func() { - for i := 0; i < min(cap(QUEUE)-len(QUEUE), 2); i++ { - resp, err := http.Get(API) + for i := 0; i < min(cap(queue)-len(queue), 2); i++ { + resp, err := http.Get(api) if err != nil { ctx.SendChain(message.Text("ERROR: ", err)) continue @@ -45,13 +46,13 @@ func init() { } url := json.Get("data.0.urls.original").Str ctx.SendGroupMessage(0, message.Image(url)) - QUEUE <- url + queue <- url } }() select { case <-time.After(time.Second * 10): ctx.SendChain(message.Text("ERROR: 等待填充,请稍后再试......")) - case url := <-QUEUE: + case url := <-queue: ctx.SendChain(message.Image(url)) } }) diff --git a/plugin_manager/manager.go b/plugin_manager/manager.go index a4367d55..30ac8cfc 100644 --- a/plugin_manager/manager.go +++ b/plugin_manager/manager.go @@ -1,4 +1,4 @@ -package plugin_manager +package manager import ( "fmt" diff --git a/plugin_minecraft/info.go b/plugin_minecraft/info.go index 28b575f5..d7c3fc79 100644 --- a/plugin_minecraft/info.go +++ b/plugin_minecraft/info.go @@ -1,12 +1,13 @@ -package plugin_minecraft +package minecraft import ( "encoding/json" "fmt" - zero "github.com/wdvxdr1123/ZeroBot" - "github.com/wdvxdr1123/ZeroBot/message" "net/http" "strings" + + zero "github.com/wdvxdr1123/ZeroBot" + "github.com/wdvxdr1123/ZeroBot/message" ) type resultjson struct { diff --git a/plugin_minecraft/manager.go b/plugin_minecraft/manager.go index 311701d6..c64bf317 100644 --- a/plugin_minecraft/manager.go +++ b/plugin_minecraft/manager.go @@ -1,11 +1,12 @@ -package plugin_minecraft +package minecraft import ( "fmt" - zero "github.com/wdvxdr1123/ZeroBot" - "github.com/wdvxdr1123/ZeroBot/message" "io/ioutil" "net/http" + + zero "github.com/wdvxdr1123/ZeroBot" + "github.com/wdvxdr1123/ZeroBot/message" ) // 此功能实现依赖MCSManager项目对服务器的管理api,mc服务器如果没有在该管理平台部署此功能无效 diff --git a/plugin_music/selecter.go b/plugin_music/selecter.go index 25e89c25..6a71572a 100644 --- a/plugin_music/selecter.go +++ b/plugin_music/selecter.go @@ -1,7 +1,8 @@ /* +Package music QQ音乐、网易云、酷狗、酷我 点歌 */ -package plugin_music +package music import ( "crypto/md5" diff --git a/plugin_runcode/code_runner.go b/plugin_runcode/code_runner.go index fdd7a36e..49f3da45 100644 --- a/plugin_runcode/code_runner.go +++ b/plugin_runcode/code_runner.go @@ -1,7 +1,8 @@ /* +Package runcode 基于 https://tool.runoob.com 的在线运行代码 */ -package plugin_runcode +package runcode import ( "errors" diff --git a/plugin_saucenao/searcher.go b/plugin_saucenao/searcher.go index 8b14a513..a5a12bf7 100644 --- a/plugin_saucenao/searcher.go +++ b/plugin_saucenao/searcher.go @@ -1,8 +1,9 @@ /* +Package saucenao - 根据 P站 ID 搜图 - 基于 saucenao 和 ascii2d 搜图 */ -package plugin_saucenao +package saucenao import ( "fmt" diff --git a/plugin_setutime/setu_geter.go b/plugin_setutime/setu_geter.go index 54325069..116e7267 100644 --- a/plugin_setutime/setu_geter.go +++ b/plugin_setutime/setu_geter.go @@ -1,4 +1,4 @@ -package plugin_setutime +package setutime import ( "fmt" @@ -16,9 +16,9 @@ import ( ) // Pools 图片缓冲池 -type Pool struct { +type imgpool struct { Lock sync.Mutex - DB *Sqlite + DB *sqlite Path string Group int64 List []string @@ -28,9 +28,9 @@ type Pool struct { } // NewPoolsCache 返回一个缓冲池对象 -func NewPools() *Pool { - cache := &Pool{ - DB: &Sqlite{DBPath: "data/SetuTime/SetuTime.db"}, +func newPools() *imgpool { + cache := &imgpool{ + DB: &sqlite{DBPath: "data/SetuTime/SetuTime.db"}, Path: "data/SetuTime/cache/", Group: 0, List: []string{"涩图", "二次元", "风景", "车万"}, // 可以自己加类别,得自己加图片进数据库 @@ -43,7 +43,7 @@ func NewPools() *Pool { panic(err) } for i := range cache.List { - if err := cache.DB.Create(cache.List[i], &pixiv.Illust{}); err != nil { + if err := cache.DB.create(cache.List[i], &pixiv.Illust{}); err != nil { panic(err) } } @@ -51,12 +51,12 @@ func NewPools() *Pool { } var ( - POOL = NewPools() + pool = newPools() limit = rate.NewManager(time.Minute*1, 5) ) func init() { // 插件主体 - zero.OnRegex(`^来份(.*)$`, firstValueInList(POOL.List)).SetBlock(true).SetPriority(20). + zero.OnRegex(`^来份(.*)$`, firstValueInList(pool.List)).SetBlock(true).SetPriority(20). Handle(func(ctx *zero.Ctx) { if !limit.Load(ctx.Event.UserID).Acquire() { ctx.SendChain(message.Text("请稍后重试0x0...")) @@ -65,43 +65,43 @@ func init() { // 插件主体 var type_ = ctx.State["regex_matched"].([]string)[1] // 补充池子 go func() { - times := min(POOL.Max-POOL.Size(type_), 2) + times := min(pool.Max-pool.size(type_), 2) for i := 0; i < times; i++ { illust := &pixiv.Illust{} // 查询出一张图片 - if err := POOL.DB.Select(type_, illust, "ORDER BY RANDOM() limit 1"); err != nil { + if err := pool.DB.find(type_, illust, "ORDER BY RANDOM() limit 1"); err != nil { ctx.SendChain(message.Text("ERROR: ", err)) continue } // 下载图片 - if _, err := download(illust, POOL.Path); err != nil { + if _, err := download(illust, pool.Path); err != nil { ctx.SendChain(message.Text("ERROR: ", err)) continue } - ctx.SendGroupMessage(POOL.Group, []message.MessageSegment{message.Image(file(illust))}) + ctx.SendGroupMessage(pool.Group, []message.MessageSegment{message.Image(file(illust))}) // 向缓冲池添加一张图片 - POOL.Push(type_, illust) + pool.push(type_, illust) time.Sleep(time.Second * 1) } }() // 如果没有缓存,阻塞5秒 - if POOL.Size(type_) == 0 { + if pool.size(type_) == 0 { ctx.SendChain(message.Text("INFO: 正在填充弹药......")) <-time.After(time.Second * 5) - if POOL.Size(type_) == 0 { + if pool.size(type_) == 0 { ctx.SendChain(message.Text("ERROR: 等待填充,请稍后再试......")) return } } // 从缓冲池里抽一张 - if id := ctx.SendChain(message.Image(file(POOL.Pop(type_)))); id == 0 { + if id := ctx.SendChain(message.Image(file(pool.pop(type_)))); id == 0 { ctx.SendChain(message.Text("ERROR: 可能被风控了")) } return }) - zero.OnRegex(`^添加(.*?)(\d+)$`, firstValueInList(POOL.List), zero.SuperUserPermission).SetBlock(true).SetPriority(21). + zero.OnRegex(`^添加(.*?)(\d+)$`, firstValueInList(pool.List), zero.SuperUserPermission).SetBlock(true).SetPriority(21). Handle(func(ctx *zero.Ctx) { var ( type_ = ctx.State["regex_matched"].([]string)[1] @@ -115,7 +115,7 @@ func init() { // 插件主体 return } // 下载插画 - if _, err := download(illust, POOL.Path); err != nil { + if _, err := download(illust, pool.Path); err != nil { ctx.SendChain(message.Text("ERROR: ", err)) return } @@ -125,7 +125,7 @@ func init() { // 插件主体 return } // 添加插画到对应的数据库table - if err := POOL.DB.Insert(type_, illust); err != nil { + if err := pool.DB.insert(type_, illust); err != nil { ctx.SendChain(message.Text("ERROR: ", err)) return } @@ -133,14 +133,14 @@ func init() { // 插件主体 return }) - zero.OnRegex(`^删除(.*?)(\d+)$`, firstValueInList(POOL.List), zero.SuperUserPermission).SetBlock(true).SetPriority(22). + zero.OnRegex(`^删除(.*?)(\d+)$`, firstValueInList(pool.List), zero.SuperUserPermission).SetBlock(true).SetPriority(22). Handle(func(ctx *zero.Ctx) { var ( type_ = ctx.State["regex_matched"].([]string)[1] id, _ = strconv.ParseInt(ctx.State["regex_matched"].([]string)[2], 10, 64) ) // 查询数据库 - if err := POOL.DB.Delete(type_, fmt.Sprintf("WHERE pid=%d", id)); err != nil { + if err := pool.DB.del(type_, fmt.Sprintf("WHERE pid=%d", id)); err != nil { ctx.Send(fmt.Sprintf("ERROR: %v", err)) return } @@ -152,13 +152,13 @@ func init() { // 插件主体 zero.OnFullMatchGroup([]string{">setu status"}).SetBlock(true).SetPriority(23). Handle(func(ctx *zero.Ctx) { state := []string{"[SetuTime]"} - for i := range POOL.List { - num, err := POOL.DB.Num(POOL.List[i]) + for i := range pool.List { + num, err := pool.DB.num(pool.List[i]) if err != nil { num = 0 } state = append(state, "\n") - state = append(state, POOL.List[i]) + state = append(state, pool.List[i]) state = append(state, ": ") state = append(state, fmt.Sprintf("%d", num)) } @@ -192,28 +192,28 @@ func min(a, b int) int { } } -// Size 返回缓冲池指定类型的现有大小 -func (p *Pool) Size(type_ string) int { +// size 返回缓冲池指定类型的现有大小 +func (p *imgpool) size(type_ string) int { return len(p.Pool[type_]) } -// IsFull 返回缓冲池指定类型是否已满 -func (p *Pool) IsFull(type_ string) bool { +// isFull 返回缓冲池指定类型是否已满 +func (p *imgpool) isFull(type_ string) bool { return len(p.Pool[type_]) >= p.Max } -// Push 向缓冲池插入一张图片 -func (p *Pool) Push(type_ string, illust *pixiv.Illust) { +// push 向缓冲池插入一张图片 +func (p *imgpool) push(type_ string, illust *pixiv.Illust) { p.Lock.Lock() defer p.Lock.Unlock() p.Pool[type_] = append(p.Pool[type_], illust) } // Push 在缓冲池拿出一张图片 -func (p *Pool) Pop(type_ string) (illust *pixiv.Illust) { +func (p *imgpool) pop(type_ string) (illust *pixiv.Illust) { p.Lock.Lock() defer p.Lock.Unlock() - if p.Size(type_) == 0 { + if p.size(type_) == 0 { return } illust = p.Pool[type_][0] @@ -224,7 +224,7 @@ func (p *Pool) Pop(type_ string) (illust *pixiv.Illust) { func file(i *pixiv.Illust) string { filename := fmt.Sprint(i.Pid) pwd, _ := os.Getwd() - filepath := pwd + `/` + POOL.Path + filename + filepath := pwd + `/` + pool.Path + filename if _, err := os.Stat(filepath + ".jpg"); err == nil || os.IsExist(err) { return `file:///` + filepath + ".jpg" } diff --git a/plugin_setutime/sqlite.go b/plugin_setutime/sqlite.go index 2d9ce597..06222df3 100644 --- a/plugin_setutime/sqlite.go +++ b/plugin_setutime/sqlite.go @@ -1,4 +1,4 @@ -package plugin_setutime +package setutime import ( "database/sql" @@ -8,16 +8,16 @@ import ( _ "modernc.org/sqlite" ) -// Sqlite 数据库对象 -type Sqlite struct { +// sqlite 数据库对象 +type sqlite struct { DB *sql.DB DBPath string } -// Create 生成数据库 +// create 生成数据库 // 默认结构体的第一个元素为主键 // 返回错误 -func (db *Sqlite) Create(table string, objptr interface{}) (err error) { +func (db *sqlite) create(table string, objptr interface{}) (err error) { if db.DB == nil { database, err := sql.Open("sqlite", db.DBPath) if err != nil { @@ -53,10 +53,10 @@ func (db *Sqlite) Create(table string, objptr interface{}) (err error) { return nil } -// Insert 插入数据集 +// insert 插入数据集 // 默认结构体的第一个元素为主键 // 返回错误 -func (db *Sqlite) Insert(table string, objptr interface{}) (err error) { +func (db *sqlite) insert(table string, objptr interface{}) (err error) { rows, err := db.DB.Query("SELECT * FROM " + table) if err != nil { return err @@ -109,11 +109,11 @@ func (db *Sqlite) Insert(table string, objptr interface{}) (err error) { return nil } -// Select 查询数据库 +// find 查询数据库 // condition 可为"WHERE id = 0" // 默认字段与结构体元素顺序一致 // 返回错误 -func (db *Sqlite) Select(table string, objptr interface{}, condition string) (err error) { +func (db *sqlite) find(table string, objptr interface{}, condition string) (err error) { var cmd = []string{} cmd = append(cmd, "SELECT * FROM ") cmd = append(cmd, table) @@ -136,10 +136,10 @@ func (db *Sqlite) Select(table string, objptr interface{}, condition string) (er return nil } -// Delete 删除数据库 +// del 删除数据库 // condition 可为"WHERE id = 0" // 返回错误 -func (db *Sqlite) Delete(table string, condition string) (err error) { +func (db *sqlite) del(table string, condition string) (err error) { var cmd = []string{} cmd = append(cmd, "DELETE FROM") cmd = append(cmd, table) @@ -155,9 +155,9 @@ func (db *Sqlite) Delete(table string, condition string) (err error) { return nil } -// Num 查询数据库行数 +// num 查询数据库行数 // 返回行数以及错误 -func (db *Sqlite) Num(table string) (num int, err error) { +func (db *sqlite) num(table string) (num int, err error) { var cmd = []string{} cmd = append(cmd, "SELECT * FROM") cmd = append(cmd, table) diff --git a/plugin_shindan/shindan.go b/plugin_shindan/shindan.go index 501ca140..e1277ab2 100644 --- a/plugin_shindan/shindan.go +++ b/plugin_shindan/shindan.go @@ -1,7 +1,8 @@ /* +Package shindan 基于 https://shindanmaker.com 的测定小功能 */ -package plugin_shindan +package shindan import ( "strconv" From 541c0d1bcaaae2a02349f3bb89a72a04ddbf1150 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 17:19:28 +0800 Subject: [PATCH 37/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_atri/atri.go | 3 +-- plugin_chat/chat.go | 5 +---- plugin_diana/bing.go | 5 +---- plugin_github/repo_searcher.go | 5 +---- plugin_lolicon/lolicon.go | 5 +---- plugin_music/selecter.go | 5 +---- plugin_runcode/code_runner.go | 5 +---- plugin_saucenao/searcher.go | 6 +----- plugin_shindan/shindan.go | 5 +---- 9 files changed, 9 insertions(+), 35 deletions(-) diff --git a/plugin_atri/atri.go b/plugin_atri/atri.go index feb232e6..3485812b 100644 --- a/plugin_atri/atri.go +++ b/plugin_atri/atri.go @@ -1,6 +1,5 @@ /* -Package atri -本文件基于 https://github.com/Kyomotoi/ATRI +Package atri 本文件基于 https://github.com/Kyomotoi/ATRI 为 Golang 移植版,语料、素材均来自上述项目 本项目遵守 AGPL v3 协议进行开源 */ diff --git a/plugin_chat/chat.go b/plugin_chat/chat.go index 3164af84..95acbdaf 100644 --- a/plugin_chat/chat.go +++ b/plugin_chat/chat.go @@ -1,7 +1,4 @@ -/* -Package chat -对话插件 example -*/ +// Package chat 对话插件 package chat import ( diff --git a/plugin_diana/bing.go b/plugin_diana/bing.go index a316244a..4a675d79 100644 --- a/plugin_diana/bing.go +++ b/plugin_diana/bing.go @@ -1,7 +1,4 @@ -/* -Package diana -虚拟偶像女团 A-SOUL 成员嘉然相关 -*/ +// Package diana 虚拟偶像女团 A-SOUL 成员嘉然相关 package diana import ( diff --git a/plugin_github/repo_searcher.go b/plugin_github/repo_searcher.go index f2a3f4c8..34101beb 100644 --- a/plugin_github/repo_searcher.go +++ b/plugin_github/repo_searcher.go @@ -1,7 +1,4 @@ -/* -Plugin github -GitHub 仓库搜索 -*/ +// Plugin github GitHub 仓库搜索 package github import ( diff --git a/plugin_lolicon/lolicon.go b/plugin_lolicon/lolicon.go index 2184396a..f1fc20ef 100644 --- a/plugin_lolicon/lolicon.go +++ b/plugin_lolicon/lolicon.go @@ -1,7 +1,4 @@ -/* -Package lolicon -基于 https://api.lolicon.app 随机图片 -*/ +// Package lolicon 基于 https://api.lolicon.app 随机图片 package lolicon import ( diff --git a/plugin_music/selecter.go b/plugin_music/selecter.go index 6a71572a..4fde2240 100644 --- a/plugin_music/selecter.go +++ b/plugin_music/selecter.go @@ -1,7 +1,4 @@ -/* -Package music -QQ音乐、网易云、酷狗、酷我 点歌 -*/ +// Package music QQ音乐、网易云、酷狗、酷我 点歌 package music import ( diff --git a/plugin_runcode/code_runner.go b/plugin_runcode/code_runner.go index 49f3da45..422efb82 100644 --- a/plugin_runcode/code_runner.go +++ b/plugin_runcode/code_runner.go @@ -1,7 +1,4 @@ -/* -Package runcode -基于 https://tool.runoob.com 的在线运行代码 -*/ +// Package runcode 基于 https://tool.runoob.com 的在线运行代码 package runcode import ( diff --git a/plugin_saucenao/searcher.go b/plugin_saucenao/searcher.go index a5a12bf7..847ceb5a 100644 --- a/plugin_saucenao/searcher.go +++ b/plugin_saucenao/searcher.go @@ -1,8 +1,4 @@ -/* -Package saucenao -- 根据 P站 ID 搜图 -- 基于 saucenao 和 ascii2d 搜图 -*/ +// Package saucenao P站ID/saucenao/ascii2d搜图 package saucenao import ( diff --git a/plugin_shindan/shindan.go b/plugin_shindan/shindan.go index e1277ab2..c34892c5 100644 --- a/plugin_shindan/shindan.go +++ b/plugin_shindan/shindan.go @@ -1,7 +1,4 @@ -/* -Package shindan -基于 https://shindanmaker.com 的测定小功能 -*/ +// Package shindan 基于 https://shindanmaker.com 的测定小功能 package shindan import ( From e477e0b4526bfcf7a0f7c7a22e34b786f55e78cc Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 17:32:17 +0800 Subject: [PATCH 38/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_diana/bing.go | 2 +- plugin_diana/text.go | 11 +++---- plugin_github/repo_searcher.go | 9 +++--- plugin_lolicon/lolicon.go | 3 +- plugin_manager/manager.go | 19 +++++------ plugin_music/selecter.go | 8 ++--- plugin_runcode/code_runner.go | 58 ++++++++++++++++------------------ plugin_setutime/setu_geter.go | 26 +++++++-------- 8 files changed, 65 insertions(+), 71 deletions(-) diff --git a/plugin_diana/bing.go b/plugin_diana/bing.go index 4a675d79..001d1219 100644 --- a/plugin_diana/bing.go +++ b/plugin_diana/bing.go @@ -60,7 +60,7 @@ func init() { zero.OnFullMatch("小作文", zero.OnlyToMe). Handle(func(ctx *zero.Ctx) { rand.Seed(time.Now().UnixNano()) - ctx.SendChain(message.Text(ARRAY[rand.Intn(len(ARRAY))])) + ctx.SendChain(message.Text(array[rand.Intn(len(array))])) }) // 逆天 diff --git a/plugin_diana/text.go b/plugin_diana/text.go index c9cd2ac7..32d087d7 100644 --- a/plugin_diana/text.go +++ b/plugin_diana/text.go @@ -13,7 +13,7 @@ const ( var ( compo Composition - ARRAY []string + array []string ) func init() { @@ -24,7 +24,7 @@ func init() { panic(err) } loadText() - ARRAY = compo.Array + array = compo.Array }() } @@ -44,18 +44,17 @@ func loadText() { func addText(txt string) error { if txt != "" { - ARRAY = append(ARRAY, txt) + array = append(array, txt) data, err := compo.Marshal() if err == nil { if _, err := os.Stat(datapath); err == nil || os.IsExist(err) { f, err1 := os.OpenFile(pbfile, os.O_WRONLY|os.O_TRUNC|os.O_CREATE, 0644) - if err1 != nil { - return err1 - } else { + if err1 == nil { defer f.Close() _, err2 := f.Write(data) return err2 } + return err1 } } return err diff --git a/plugin_github/repo_searcher.go b/plugin_github/repo_searcher.go index 34101beb..dc5a006d 100644 --- a/plugin_github/repo_searcher.go +++ b/plugin_github/repo_searcher.go @@ -1,8 +1,7 @@ -// Plugin github GitHub 仓库搜索 +// Package github GitHub 仓库搜索 package github import ( - "errors" "fmt" "io/ioutil" "net/http" @@ -64,9 +63,9 @@ func init() { // 插件主体 } // notnull 如果传入文本为空,则返回默认值 -func notnull(text, default_ string) string { +func notnull(text, defstr string) string { if text == "" { - return default_ + return defstr } return text } @@ -91,7 +90,7 @@ func netGet(dest string, header http.Header) ([]byte, error) { } if code := resp.StatusCode; code != 200 { // 如果返回不是200则立刻抛出错误 - return nil, errors.New(fmt.Sprintf("code %d", code)) + return nil, fmt.Errorf("code %d", code) } return body, nil } diff --git a/plugin_lolicon/lolicon.go b/plugin_lolicon/lolicon.go index f1fc20ef..dd68dcdd 100644 --- a/plugin_lolicon/lolicon.go +++ b/plugin_lolicon/lolicon.go @@ -58,7 +58,6 @@ func init() { func min(a, b int) int { if a < b { return a - } else { - return b } + return b } diff --git a/plugin_manager/manager.go b/plugin_manager/manager.go index 30ac8cfc..dae56bb5 100644 --- a/plugin_manager/manager.go +++ b/plugin_manager/manager.go @@ -1,3 +1,4 @@ +// Package manager 群管 package manager import ( @@ -114,9 +115,9 @@ func init() { // 插件主体 case "分钟": // case "小时": - duration = duration * 60 + duration *= 60 case "天": - duration = duration * 60 * 24 + duration *= 60 * 24 default: // } @@ -246,7 +247,7 @@ func init() { // 插件主体 t, ok := (*timer.Timers)[ti] if ok { t.Enable = false - delete(*timer.Timers, ti) //避免重复取消 + delete(*timer.Timers, ti) // 避免重复取消 _ = timer.SaveTimers() ctx.Send("取消成功~") } else { @@ -254,7 +255,7 @@ func init() { // 插件主体 } } }) - //列出本群所有定时 + // 列出本群所有定时 zero.OnFullMatch("列出所有提醒", zero.SuperUserPermission).SetBlock(true).SetPriority(40). Handle(func(ctx *zero.Ctx) { if ctx.Event.GroupID > 0 { @@ -267,12 +268,12 @@ func init() { // 插件主体 if ctx.Event.GroupID > 0 { list := ctx.GetGroupMemberList(ctx.Event.GroupID) rand.Seed(time.Now().UnixNano()) - rand_index := fmt.Sprint(rand.Intn(int(list.Get("#").Int()))) - random_card := list.Get(rand_index + ".card").String() - if random_card == "" { - random_card = list.Get(rand_index + ".nickname").String() + randIndex := fmt.Sprint(rand.Intn(int(list.Get("#").Int()))) + randCard := list.Get(randIndex + ".card").String() + if randCard == "" { + randCard = list.Get(randIndex + ".nickname").String() } - ctx.Send(random_card + ",就是你啦!") + ctx.Send(randCard + ",就是你啦!") } }) // 入群欢迎 diff --git a/plugin_music/selecter.go b/plugin_music/selecter.go index 4fde2240..7927fd71 100644 --- a/plugin_music/selecter.go +++ b/plugin_music/selecter.go @@ -219,9 +219,9 @@ func md5str(s string) string { } // netGet 返回请求数据 -func netGet(get_url string, header http.Header) []byte { +func netGet(url string, header http.Header) []byte { client := &http.Client{} - request, _ := http.NewRequest("GET", get_url, nil) + request, _ := http.NewRequest("GET", url, nil) request.Header = header res, err := client.Do(request) if err != nil { @@ -233,9 +233,9 @@ func netGet(get_url string, header http.Header) []byte { } // netPost 返回请求数据 -func netPost(post_url string, data url.Values, header http.Header) []byte { +func netPost(url string, data url.Values, header http.Header) []byte { client := &http.Client{} - request, _ := http.NewRequest("POST", post_url, strings.NewReader(data.Encode())) + request, _ := http.NewRequest("POST", url, strings.NewReader(data.Encode())) request.Header = header res, err := client.Do(request) if err != nil { diff --git a/plugin_runcode/code_runner.go b/plugin_runcode/code_runner.go index 422efb82..82d99dec 100644 --- a/plugin_runcode/code_runner.go +++ b/plugin_runcode/code_runner.go @@ -148,38 +148,34 @@ func init() { message.Text("> ", ctx.Event.Sender.NickName, "\n"), message.Text("在线运行代码功能已被禁用"), ) - return - } - // 执行运行 - block := ctx.State["regex_matched"].([]string)[2] - block = message.UnescapeCQCodeText(block) - - if block == "help" { - // 输出模板 - ctx.SendChain( - message.Text("> ", ctx.Event.Sender.NickName, " ", language, "-template:\n"), - message.Text( - ">runcode ", language, "\n", - templates[language], - ), - ) - return - } - - if output, err := runCode(block, runType); err != nil { - // 运行失败 - ctx.SendChain( - message.Text("> ", ctx.Event.Sender.NickName, "\n"), - message.Text("ERROR: ", err), - ) - return } else { - // 运行成功 - ctx.SendChain( - message.Text("> ", ctx.Event.Sender.NickName, "\n"), - message.Text(output), - ) - return + // 执行运行 + block := ctx.State["regex_matched"].([]string)[2] + block = message.UnescapeCQCodeText(block) + if block == "help" { + // 输出模板 + ctx.SendChain( + message.Text("> ", ctx.Event.Sender.NickName, " ", language, "-template:\n"), + message.Text( + ">runcode ", language, "\n", + templates[language], + ), + ) + } else { + if output, err := runCode(block, runType); err != nil { + // 运行失败 + ctx.SendChain( + message.Text("> ", ctx.Event.Sender.NickName, "\n"), + message.Text("ERROR: ", err), + ) + } else { + // 运行成功 + ctx.SendChain( + message.Text("> ", ctx.Event.Sender.NickName, "\n"), + message.Text(output), + ) + } + } } } }) diff --git a/plugin_setutime/setu_geter.go b/plugin_setutime/setu_geter.go index 116e7267..030f449f 100644 --- a/plugin_setutime/setu_geter.go +++ b/plugin_setutime/setu_geter.go @@ -62,14 +62,14 @@ func init() { // 插件主体 ctx.SendChain(message.Text("请稍后重试0x0...")) return } - var type_ = ctx.State["regex_matched"].([]string)[1] + var imgtype = ctx.State["regex_matched"].([]string)[1] // 补充池子 go func() { - times := min(pool.Max-pool.size(type_), 2) + times := min(pool.Max-pool.size(imgtype), 2) for i := 0; i < times; i++ { illust := &pixiv.Illust{} // 查询出一张图片 - if err := pool.DB.find(type_, illust, "ORDER BY RANDOM() limit 1"); err != nil { + if err := pool.DB.find(imgtype, illust, "ORDER BY RANDOM() limit 1"); err != nil { ctx.SendChain(message.Text("ERROR: ", err)) continue } @@ -80,22 +80,22 @@ func init() { // 插件主体 } ctx.SendGroupMessage(pool.Group, []message.MessageSegment{message.Image(file(illust))}) // 向缓冲池添加一张图片 - pool.push(type_, illust) + pool.push(imgtype, illust) time.Sleep(time.Second * 1) } }() // 如果没有缓存,阻塞5秒 - if pool.size(type_) == 0 { + if pool.size(imgtype) == 0 { ctx.SendChain(message.Text("INFO: 正在填充弹药......")) <-time.After(time.Second * 5) - if pool.size(type_) == 0 { + if pool.size(imgtype) == 0 { ctx.SendChain(message.Text("ERROR: 等待填充,请稍后再试......")) return } } // 从缓冲池里抽一张 - if id := ctx.SendChain(message.Image(file(pool.pop(type_)))); id == 0 { + if id := ctx.SendChain(message.Image(file(pool.pop(imgtype)))); id == 0 { ctx.SendChain(message.Text("ERROR: 可能被风控了")) } return @@ -104,8 +104,8 @@ func init() { // 插件主体 zero.OnRegex(`^添加(.*?)(\d+)$`, firstValueInList(pool.List), zero.SuperUserPermission).SetBlock(true).SetPriority(21). Handle(func(ctx *zero.Ctx) { var ( - type_ = ctx.State["regex_matched"].([]string)[1] - id, _ = strconv.ParseInt(ctx.State["regex_matched"].([]string)[2], 10, 64) + imgtype = ctx.State["regex_matched"].([]string)[1] + id, _ = strconv.ParseInt(ctx.State["regex_matched"].([]string)[2], 10, 64) ) ctx.SendChain(message.Text("少女祈祷中......")) // 查询P站插图信息 @@ -125,7 +125,7 @@ func init() { // 插件主体 return } // 添加插画到对应的数据库table - if err := pool.DB.insert(type_, illust); err != nil { + if err := pool.DB.insert(imgtype, illust); err != nil { ctx.SendChain(message.Text("ERROR: ", err)) return } @@ -136,11 +136,11 @@ func init() { // 插件主体 zero.OnRegex(`^删除(.*?)(\d+)$`, firstValueInList(pool.List), zero.SuperUserPermission).SetBlock(true).SetPriority(22). Handle(func(ctx *zero.Ctx) { var ( - type_ = ctx.State["regex_matched"].([]string)[1] - id, _ = strconv.ParseInt(ctx.State["regex_matched"].([]string)[2], 10, 64) + imgtype = ctx.State["regex_matched"].([]string)[1] + id, _ = strconv.ParseInt(ctx.State["regex_matched"].([]string)[2], 10, 64) ) // 查询数据库 - if err := pool.DB.del(type_, fmt.Sprintf("WHERE pid=%d", id)); err != nil { + if err := pool.DB.del(imgtype, fmt.Sprintf("WHERE pid=%d", id)); err != nil { ctx.Send(fmt.Sprintf("ERROR: %v", err)) return } From ce406d8f552e99cf497eee43588a54f66881f8f4 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 17:44:48 +0800 Subject: [PATCH 39/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_bilibili/info.go | 1 + plugin_diana/bing.go | 6 +++- plugin_diana/text.go | 12 ++++--- plugin_github/repo_searcher.go | 3 +- plugin_image_finder/keyword.go | 6 ++-- plugin_minecraft/info.go | 4 +-- plugin_minecraft/manager.go | 4 +-- plugin_runcode/code_runner.go | 65 +++++++++++++++++----------------- plugin_setutime/setu_geter.go | 20 +++++------ plugin_setutime/sqlite.go | 2 +- 10 files changed, 66 insertions(+), 57 deletions(-) diff --git a/plugin_bilibili/info.go b/plugin_bilibili/info.go index 5741bd3f..84d39a18 100644 --- a/plugin_bilibili/info.go +++ b/plugin_bilibili/info.go @@ -1,3 +1,4 @@ +// Package bilibili 查询b站用户信息 package bilibili import ( diff --git a/plugin_diana/bing.go b/plugin_diana/bing.go index 001d1219..8ebc996d 100644 --- a/plugin_diana/bing.go +++ b/plugin_diana/bing.go @@ -2,6 +2,7 @@ package diana import ( + fmt "fmt" "math/rand" "time" @@ -71,6 +72,9 @@ func init() { // 增加小作文 zero.OnRegex(`^教你一篇小作文(.*)$`, zero.AdminPermission). Handle(func(ctx *zero.Ctx) { - addText(ctx.State["regex_matched"].([]string)[1]) + err := addText(ctx.State["regex_matched"].([]string)[1]) + if err != nil { + ctx.Send(fmt.Sprintf("ERROR: %v", err)) + } }) } diff --git a/plugin_diana/text.go b/plugin_diana/text.go index 32d087d7..f9ea7bc8 100644 --- a/plugin_diana/text.go +++ b/plugin_diana/text.go @@ -23,23 +23,27 @@ func init() { if err != nil { panic(err) } - loadText() - array = compo.Array + if loadText() == nil { + array = compo.Array + } }() } -func loadText() { +func loadText() error { if _, err := os.Stat(pbfile); err == nil || os.IsExist(err) { f, err := os.Open(pbfile) if err == nil { data, err1 := io.ReadAll(f) if err1 == nil { if len(data) > 0 { - compo.Unmarshal(data) + return compo.Unmarshal(data) } } + return err1 } + return err } + return nil } func addText(txt string) error { diff --git a/plugin_github/repo_searcher.go b/plugin_github/repo_searcher.go index dc5a006d..a119a8c8 100644 --- a/plugin_github/repo_searcher.go +++ b/plugin_github/repo_searcher.go @@ -2,6 +2,7 @@ package github import ( + "errors" "fmt" "io/ioutil" "net/http" @@ -90,7 +91,7 @@ func netGet(dest string, header http.Header) ([]byte, error) { } if code := resp.StatusCode; code != 200 { // 如果返回不是200则立刻抛出错误 - return nil, fmt.Errorf("code %d", code) + return nil, errors.New(fmt.Sprintf("code %d", code)) } return body, nil } diff --git a/plugin_image_finder/keyword.go b/plugin_image_finder/keyword.go index 15f7d572..4e49eefd 100644 --- a/plugin_image_finder/keyword.go +++ b/plugin_image_finder/keyword.go @@ -63,7 +63,7 @@ func init() { keyword := ctx.State["regex_matched"].([]string)[1] soutujson := soutuapi(keyword) pom1 := "https://i.pixiv.cat" - rannum := rand_int() + rannum := randint() pom2 := soutujson.Illusts[rannum].ImageUrls.Large[19:] ctx.SendChain(message.Image(pom1 + pom2)) }) @@ -97,8 +97,8 @@ func soutuapi(keyword string) *resultjson { return result } -// rand_int 从json里的30条数据中随机获取一条返回 -func rand_int() int { +// randint 从json里的30条数据中随机获取一条返回 +func randint() int { rand.Seed(time.Now().UnixNano()) return rand.Intn(30) } diff --git a/plugin_minecraft/info.go b/plugin_minecraft/info.go index d7c3fc79..841f4ed0 100644 --- a/plugin_minecraft/info.go +++ b/plugin_minecraft/info.go @@ -42,7 +42,7 @@ func init() { // 支持多个服务器 switch ctx.State["regex_matched"].([]string)[1] { case "ftbi": // 这里对应触发指令里的服务器名称 - ftbijson := infoapi("115.28.186.22:25710") //这里填对应mc服务器的登录地址 + ftbijson := infoapi("115.28.186.22:25710") // 这里填对应mc服务器的登录地址 var str = ftbijson.Players.List cs := strings.Join(str, "\n") ctx.SendChain(message.Text( @@ -51,7 +51,7 @@ func init() { "以下为玩家名字: ", "\n", cs, )) case "ges": // 这里对应触发指令里的服务器名称 - gesjson := infoapi("115.28.186.22:25701") //这里填对应mc服务器的登录地址 + gesjson := infoapi("115.28.186.22:25701") // 这里填对应mc服务器的登录地址 var str = gesjson.Players.List cs := strings.Join(str, "\n") ctx.SendChain(message.Text( diff --git a/plugin_minecraft/manager.go b/plugin_minecraft/manager.go index c64bf317..b82c01da 100644 --- a/plugin_minecraft/manager.go +++ b/plugin_minecraft/manager.go @@ -33,7 +33,7 @@ func init() { }) } -//开启服务器的api请求 +// 开启服务器的api请求 func start(name string) string { url := fmt.Sprintf("http://your.addr:23333/api/start_server/%s/?apikey=apikey", name) client := &http.Client{} @@ -54,7 +54,7 @@ func start(name string) string { return string(body) } -//关闭服务器的api请求 +// 关闭服务器的api请求 func stop(name string) string { url := fmt.Sprintf("http://your.addr:23333/api/stop_server/%s/?apikey=apikey", name) client := &http.Client{} diff --git a/plugin_runcode/code_runner.go b/plugin_runcode/code_runner.go index 82d99dec..f6cad44a 100644 --- a/plugin_runcode/code_runner.go +++ b/plugin_runcode/code_runner.go @@ -130,50 +130,49 @@ func init() { Handle(func(ctx *zero.Ctx) { if !limit.Load(ctx.Event.UserID).Acquire() { ctx.Send("请稍后重试0x0...") - return - } - language := ctx.State["regex_matched"].([]string)[1] - language = strings.ToLower(language) - if runType, exist := table[language]; !exist { - // 不支持语言 - ctx.SendChain( - message.Text("> ", ctx.Event.Sender.NickName, "\n"), - message.Text("语言不是受支持的编程语种呢~"), - ) - return } else { - if RunAllow == false { - // 运行代码被禁用 + language := ctx.State["regex_matched"].([]string)[1] + language = strings.ToLower(language) + if runType, exist := table[language]; !exist { + // 不支持语言 ctx.SendChain( message.Text("> ", ctx.Event.Sender.NickName, "\n"), - message.Text("在线运行代码功能已被禁用"), + message.Text("语言不是受支持的编程语种呢~"), ) } else { - // 执行运行 - block := ctx.State["regex_matched"].([]string)[2] - block = message.UnescapeCQCodeText(block) - if block == "help" { - // 输出模板 + if RunAllow == false { + // 运行代码被禁用 ctx.SendChain( - message.Text("> ", ctx.Event.Sender.NickName, " ", language, "-template:\n"), - message.Text( - ">runcode ", language, "\n", - templates[language], - ), + message.Text("> ", ctx.Event.Sender.NickName, "\n"), + message.Text("在线运行代码功能已被禁用"), ) } else { - if output, err := runCode(block, runType); err != nil { - // 运行失败 + // 执行运行 + block := ctx.State["regex_matched"].([]string)[2] + block = message.UnescapeCQCodeText(block) + if block == "help" { + // 输出模板 ctx.SendChain( - message.Text("> ", ctx.Event.Sender.NickName, "\n"), - message.Text("ERROR: ", err), + message.Text("> ", ctx.Event.Sender.NickName, " ", language, "-template:\n"), + message.Text( + ">runcode ", language, "\n", + templates[language], + ), ) } else { - // 运行成功 - ctx.SendChain( - message.Text("> ", ctx.Event.Sender.NickName, "\n"), - message.Text(output), - ) + if output, err := runCode(block, runType); err != nil { + // 运行失败 + ctx.SendChain( + message.Text("> ", ctx.Event.Sender.NickName, "\n"), + message.Text("ERROR: ", err), + ) + } else { + // 运行成功 + ctx.SendChain( + message.Text("> ", ctx.Event.Sender.NickName, "\n"), + message.Text(output), + ) + } } } } diff --git a/plugin_setutime/setu_geter.go b/plugin_setutime/setu_geter.go index 030f449f..fe899e21 100644 --- a/plugin_setutime/setu_geter.go +++ b/plugin_setutime/setu_geter.go @@ -193,31 +193,31 @@ func min(a, b int) int { } // size 返回缓冲池指定类型的现有大小 -func (p *imgpool) size(type_ string) int { - return len(p.Pool[type_]) +func (p *imgpool) size(imgtype string) int { + return len(p.Pool[imgtype]) } // isFull 返回缓冲池指定类型是否已满 -func (p *imgpool) isFull(type_ string) bool { - return len(p.Pool[type_]) >= p.Max +func (p *imgpool) isFull(imgtype_ string) bool { + return len(p.Pool[imgtype_]) >= p.Max } // push 向缓冲池插入一张图片 -func (p *imgpool) push(type_ string, illust *pixiv.Illust) { +func (p *imgpool) push(imgtype_ string, illust *pixiv.Illust) { p.Lock.Lock() defer p.Lock.Unlock() - p.Pool[type_] = append(p.Pool[type_], illust) + p.Pool[imgtype_] = append(p.Pool[imgtype_], illust) } // Push 在缓冲池拿出一张图片 -func (p *imgpool) pop(type_ string) (illust *pixiv.Illust) { +func (p *imgpool) pop(imgtype_ string) (illust *pixiv.Illust) { p.Lock.Lock() defer p.Lock.Unlock() - if p.size(type_) == 0 { + if p.size(imgtype_) == 0 { return } - illust = p.Pool[type_][0] - p.Pool[type_] = p.Pool[type_][1:] + illust = p.Pool[imgtype_][0] + p.Pool[imgtype_] = p.Pool[imgtype_][1:] return } diff --git a/plugin_setutime/sqlite.go b/plugin_setutime/sqlite.go index 06222df3..cd6961c8 100644 --- a/plugin_setutime/sqlite.go +++ b/plugin_setutime/sqlite.go @@ -5,7 +5,7 @@ import ( "reflect" "strings" - _ "modernc.org/sqlite" + _ "modernc.org/sqlite" // 引入sqlite ) // sqlite 数据库对象 From bf78603d19242c88142f2bd3d32a352d952492aa Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 18:03:03 +0800 Subject: [PATCH 40/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_chat/chat.go | 1 - plugin_diana/zhiwang.go | 17 ++++++++--------- plugin_manager/manager.go | 4 ++-- plugin_music/selecter.go | 1 - plugin_runcode/code_runner.go | 23 +++++++++++------------ plugin_setutime/setu_geter.go | 35 ++++++++++++++++------------------- plugin_setutime/sqlite.go | 3 +++ 7 files changed, 40 insertions(+), 44 deletions(-) diff --git a/plugin_chat/chat.go b/plugin_chat/chat.go index 95acbdaf..e1110927 100644 --- a/plugin_chat/chat.go +++ b/plugin_chat/chat.go @@ -44,7 +44,6 @@ func init() { // 插件主体 default: // 频繁触发,不回复 } - return }) // 群空调 var AirConditTemp = map[int64]int{} diff --git a/plugin_diana/zhiwang.go b/plugin_diana/zhiwang.go index 88daf72d..3d968b25 100644 --- a/plugin_diana/zhiwang.go +++ b/plugin_diana/zhiwang.go @@ -28,7 +28,7 @@ type zhiwang struct { // 小作文查重: 回复要查的消息 查重 func init() { - zero.OnMessage(fullMatchText("查重")). + zero.OnMessage(fullmatch("查重")). Handle(func(ctx *zero.Ctx) { msg := ctx.Event.Message if msg[0].Type == "reply" { @@ -36,7 +36,7 @@ func init() { msg := ctx.GetMessage(int64(id)).Elements[0].Data["text"] zhiwangjson := zhiwangapi(msg) - if zhiwangjson.Code != 0 { + if zhiwangjson == nil || zhiwangjson.Code != 0 { ctx.Send("api返回错误") return } @@ -60,8 +60,6 @@ func init() { "查重结果仅作参考,请注意辨别是否为原创", "\n", "数据来源: https://asoulcnki.asia/", )) - } else { - return } }) } @@ -73,24 +71,25 @@ func zhiwangapi(Text string) *zhiwang { post := "{\n\"text\":\"" + Text + "\"\n}" var jsonStr = []byte(post) - req, err := http.NewRequest("POST", url, bytes.NewBuffer(jsonStr)) + req, _ := http.NewRequest("POST", url, bytes.NewBuffer(jsonStr)) req.Header.Set("Content-Type", "application/json") client := &http.Client{} resp, err := client.Do(req) + if err != nil { - panic(err) + return nil } defer resp.Body.Close() result := &zhiwang{} - if err := json.NewDecoder(resp.Body).Decode(result); err != nil { - panic(err) + if err1 := json.NewDecoder(resp.Body).Decode(result); err1 != nil { + return nil } return result } -func fullMatchText(src ...string) zero.Rule { +func fullmatch(src ...string) zero.Rule { return func(ctx *zero.Ctx) bool { msg := ctx.Event.Message for _, elem := range msg { diff --git a/plugin_manager/manager.go b/plugin_manager/manager.go index dae56bb5..20abae21 100644 --- a/plugin_manager/manager.go +++ b/plugin_manager/manager.go @@ -149,9 +149,9 @@ func init() { // 插件主体 case "分钟": // case "小时": - duration = duration * 60 + duration *= 60 case "天": - duration = duration * 60 * 24 + duration *= 60 * 24 default: // } diff --git a/plugin_music/selecter.go b/plugin_music/selecter.go index 7927fd71..e40d0ebd 100644 --- a/plugin_music/selecter.go +++ b/plugin_music/selecter.go @@ -37,7 +37,6 @@ func init() { default: // 默认 QQ音乐 ctx.SendChain(qqmusic(ctx.State["regex_matched"].([]string)[2])) } - return }) } diff --git a/plugin_runcode/code_runner.go b/plugin_runcode/code_runner.go index f6cad44a..88cc4403 100644 --- a/plugin_runcode/code_runner.go +++ b/plugin_runcode/code_runner.go @@ -16,12 +16,10 @@ import ( "github.com/tidwall/gjson" ) -var limit = rate.NewManager(time.Minute*3, 5) - -func init() { - RunAllow := true - - templates := map[string]string{ +var ( + enable = true + limit = rate.NewManager(time.Minute*3, 5) + templates = map[string]string{ "py2": "print 'Hello World!'", "ruby": "puts \"Hello World!\";", "rb": "puts \"Hello World!\";", @@ -56,8 +54,7 @@ func init() { "typescript": "const hello : string = \"Hello World!\"\nconsole.log(hello)", "ts": "const hello : string = \"Hello World!\"\nconsole.log(hello)", } - - table := map[string][2]string{ + table = map[string][2]string{ "py2": {"0", "py"}, "ruby": {"1", "rb"}, "rb": {"1", "rb"}, @@ -92,7 +89,9 @@ func init() { "typescript": {"1010", "ts"}, "ts": {"1010", "ts"}, } +) +func init() { zero.OnFullMatch(">runcode help").SetBlock(true).FirstPriority(). Handle(func(ctx *zero.Ctx) { ctx.SendChain(message.Text( @@ -110,7 +109,7 @@ func init() { zero.OnFullMatch(">runcode on", zero.AdminPermission).SetBlock(true).FirstPriority(). Handle(func(ctx *zero.Ctx) { - RunAllow = true + enable = true ctx.SendChain( message.Text("> ", ctx.Event.Sender.NickName, "\n"), message.Text("在线运行代码功能已启用"), @@ -119,7 +118,7 @@ func init() { zero.OnFullMatch(">runcode off", zero.AdminPermission).SetBlock(true).FirstPriority(). Handle(func(ctx *zero.Ctx) { - RunAllow = false + enable = false ctx.SendChain( message.Text("> ", ctx.Event.Sender.NickName, "\n"), message.Text("在线运行代码功能已禁用"), @@ -140,7 +139,7 @@ func init() { message.Text("语言不是受支持的编程语种呢~"), ) } else { - if RunAllow == false { + if !enable { // 运行代码被禁用 ctx.SendChain( message.Text("> ", ctx.Event.Sender.NickName, "\n"), @@ -199,7 +198,7 @@ func runCode(code string, runType [2]string) (string, error) { } // 发送请求 client := &http.Client{ - Timeout: time.Duration(15 * time.Second), + Timeout: 15 * time.Second, } request, _ := http.NewRequest("POST", api, strings.NewReader(val.Encode())) request.Header = header diff --git a/plugin_setutime/setu_geter.go b/plugin_setutime/setu_geter.go index fe899e21..0fd46873 100644 --- a/plugin_setutime/setu_geter.go +++ b/plugin_setutime/setu_geter.go @@ -74,7 +74,7 @@ func init() { // 插件主体 continue } // 下载图片 - if _, err := download(illust, pool.Path); err != nil { + if err := download(illust, pool.Path); err != nil { ctx.SendChain(message.Text("ERROR: ", err)) continue } @@ -98,7 +98,6 @@ func init() { // 插件主体 if id := ctx.SendChain(message.Image(file(pool.pop(imgtype)))); id == 0 { ctx.SendChain(message.Text("ERROR: 可能被风控了")) } - return }) zero.OnRegex(`^添加(.*?)(\d+)$`, firstValueInList(pool.List), zero.SuperUserPermission).SetBlock(true).SetPriority(21). @@ -115,7 +114,7 @@ func init() { // 插件主体 return } // 下载插画 - if _, err := download(illust, pool.Path); err != nil { + if err := download(illust, pool.Path); err != nil { ctx.SendChain(message.Text("ERROR: ", err)) return } @@ -130,7 +129,6 @@ func init() { // 插件主体 return } ctx.Send("添加成功") - return }) zero.OnRegex(`^删除(.*?)(\d+)$`, firstValueInList(pool.List), zero.SuperUserPermission).SetBlock(true).SetPriority(22). @@ -145,7 +143,6 @@ func init() { // 插件主体 return } ctx.Send("删除成功") - return }) // 查询数据库涩图数量 @@ -163,7 +160,6 @@ func init() { // 插件主体 state = append(state, fmt.Sprintf("%d", num)) } ctx.Send(strings.Join(state, "")) - return }) } @@ -198,26 +194,26 @@ func (p *imgpool) size(imgtype string) int { } // isFull 返回缓冲池指定类型是否已满 -func (p *imgpool) isFull(imgtype_ string) bool { - return len(p.Pool[imgtype_]) >= p.Max +func (p *imgpool) isFull(imgtype string) bool { + return len(p.Pool[imgtype]) >= p.Max } // push 向缓冲池插入一张图片 -func (p *imgpool) push(imgtype_ string, illust *pixiv.Illust) { +func (p *imgpool) push(imgtype string, illust *pixiv.Illust) { p.Lock.Lock() defer p.Lock.Unlock() - p.Pool[imgtype_] = append(p.Pool[imgtype_], illust) + p.Pool[imgtype] = append(p.Pool[imgtype], illust) } // Push 在缓冲池拿出一张图片 -func (p *imgpool) pop(imgtype_ string) (illust *pixiv.Illust) { +func (p *imgpool) pop(imgtype string) (illust *pixiv.Illust) { p.Lock.Lock() defer p.Lock.Unlock() - if p.size(imgtype_) == 0 { + if p.size(imgtype) == 0 { return } - illust = p.Pool[imgtype_][0] - p.Pool[imgtype_] = p.Pool[imgtype_][1:] + illust = p.Pool[imgtype][0] + p.Pool[imgtype] = p.Pool[imgtype][1:] return } @@ -237,17 +233,17 @@ func file(i *pixiv.Illust) string { return "" } -func download(i *pixiv.Illust, filedir string) (string, error) { +func download(i *pixiv.Illust, filedir string) /*(string, */ error /*)*/ { filename := fmt.Sprint(i.Pid) filepath := filedir + filename if _, err := os.Stat(filepath + ".jpg"); err == nil || os.IsExist(err) { - return filepath + ".jpg", nil + return /*filepath + ".jpg",*/ nil } if _, err := os.Stat(filepath + ".png"); err == nil || os.IsExist(err) { - return filepath + ".png", nil + return /*filepath + ".png",*/ nil } if _, err := os.Stat(filepath + ".gif"); err == nil || os.IsExist(err) { - return filepath + ".gif", nil + return /*filepath + ".gif",*/ nil } // 下载最大分辨率为 1200 的图片 link := i.ImageUrls @@ -255,5 +251,6 @@ func download(i *pixiv.Illust, filedir string) (string, error) { link = strings.ReplaceAll(link, "_p0", "_p0_master1200") link = strings.ReplaceAll(link, ".png", ".jpg") // 下载 - return pixiv.Download(link, filedir, filename) + _, err1 := pixiv.Download(link, filedir, filename) + return err1 } diff --git a/plugin_setutime/sqlite.go b/plugin_setutime/sqlite.go index cd6961c8..f725cf4f 100644 --- a/plugin_setutime/sqlite.go +++ b/plugin_setutime/sqlite.go @@ -61,6 +61,9 @@ func (db *sqlite) insert(table string, objptr interface{}) (err error) { if err != nil { return err } + if rows.Err() != nil { + return rows.Err() + } tags, _ := rows.Columns() rows.Close() var ( From 58bc1758ec083d3ef341fbb4254bb86491123223 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 18:11:32 +0800 Subject: [PATCH 41/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_diana/bing.go | 3 ++- plugin_diana/zhiwang.go | 4 ++-- plugin_image_finder/keyword.go | 1 + plugin_minecraft/manager.go | 1 + plugin_setutime/setu_geter.go | 5 +++-- plugin_setutime/sqlite.go | 10 ++++++++-- 6 files changed, 17 insertions(+), 7 deletions(-) diff --git a/plugin_diana/bing.go b/plugin_diana/bing.go index 8ebc996d..2b576fa2 100644 --- a/plugin_diana/bing.go +++ b/plugin_diana/bing.go @@ -65,9 +65,10 @@ func init() { }) // 逆天 + // \u200b 是 🥵 的转义 zero.OnFullMatch("发大病", zero.OnlyToMe). Handle(func(ctx *zero.Ctx) { - ctx.Send("贝拉抽我🥵嘉然骑在我背上🥵晚晚踩我🥵乃琳坐在王座是用看垃圾的眼神看我🥵🥵珈乐踢我🥵🥵,把我眼睛蒙住然后五只脚一起踩我🥵还让我猜脚是谁的,猜错了给我劈眼一铁棍🥵​") + ctx.Send("贝拉抽我\u200b嘉然骑在我背上\u200b晚晚踩我\u200b乃琳坐在王座是用看垃圾的眼神看我\u200b\u200b珈乐踢我\u200b\u200b,把我眼睛蒙住然后五只脚一起踩我\u200b还让我猜脚是谁的,猜错了给我劈眼一铁棍\u200b​") }) // 增加小作文 zero.OnRegex(`^教你一篇小作文(.*)$`, zero.AdminPermission). diff --git a/plugin_diana/zhiwang.go b/plugin_diana/zhiwang.go index 3d968b25..52ca3967 100644 --- a/plugin_diana/zhiwang.go +++ b/plugin_diana/zhiwang.go @@ -65,10 +65,10 @@ func init() { } // 发起api请求并把返回body交由json库解析 -func zhiwangapi(Text string) *zhiwang { +func zhiwangapi(text string) *zhiwang { url := "https://asoulcnki.asia/v1/api/check" - post := "{\n\"text\":\"" + Text + "\"\n}" + post := "{\n\"text\":\"" + text + "\"\n}" var jsonStr = []byte(post) req, _ := http.NewRequest("POST", url, bytes.NewBuffer(jsonStr)) diff --git a/plugin_image_finder/keyword.go b/plugin_image_finder/keyword.go index 4e49eefd..a5764416 100644 --- a/plugin_image_finder/keyword.go +++ b/plugin_image_finder/keyword.go @@ -1,3 +1,4 @@ +// Package imagefinder 关键字搜图 package imagefinder import ( diff --git a/plugin_minecraft/manager.go b/plugin_minecraft/manager.go index b82c01da..39149b38 100644 --- a/plugin_minecraft/manager.go +++ b/plugin_minecraft/manager.go @@ -1,3 +1,4 @@ +// Package minecraft MCSManager package minecraft import ( diff --git a/plugin_setutime/setu_geter.go b/plugin_setutime/setu_geter.go index 0fd46873..a9448da9 100644 --- a/plugin_setutime/setu_geter.go +++ b/plugin_setutime/setu_geter.go @@ -150,7 +150,7 @@ func init() { // 插件主体 Handle(func(ctx *zero.Ctx) { state := []string{"[SetuTime]"} for i := range pool.List { - num, err := pool.DB.num(pool.List[i]) + num, err := pool.DB.count(pool.List[i]) if err != nil { num = 0 } @@ -193,10 +193,11 @@ func (p *imgpool) size(imgtype string) int { return len(p.Pool[imgtype]) } +/* // isFull 返回缓冲池指定类型是否已满 func (p *imgpool) isFull(imgtype string) bool { return len(p.Pool[imgtype]) >= p.Max -} +}*/ // push 向缓冲池插入一张图片 func (p *imgpool) push(imgtype string, illust *pixiv.Illust) { diff --git a/plugin_setutime/sqlite.go b/plugin_setutime/sqlite.go index f725cf4f..e0a2de6a 100644 --- a/plugin_setutime/sqlite.go +++ b/plugin_setutime/sqlite.go @@ -125,6 +125,9 @@ func (db *sqlite) find(table string, objptr interface{}, condition string) (err if err != nil { return err } + if rows.Err() != nil { + return rows.Err() + } defer rows.Close() for rows.Next() { @@ -158,9 +161,9 @@ func (db *sqlite) del(table string, condition string) (err error) { return nil } -// num 查询数据库行数 +// count 查询数据库行数 // 返回行数以及错误 -func (db *sqlite) num(table string) (num int, err error) { +func (db *sqlite) count(table string) (num int, err error) { var cmd = []string{} cmd = append(cmd, "SELECT * FROM") cmd = append(cmd, table) @@ -168,6 +171,9 @@ func (db *sqlite) num(table string) (num int, err error) { if err != nil { return num, err } + if rows.Err() != nil { + return num, rows.Err() + } defer rows.Close() for rows.Next() { num++ From 3814d179268920876b761b2f09faaa52c66f2459 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 18:19:50 +0800 Subject: [PATCH 42/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_diana/bing.go | 5 +++-- plugin_setutime/setu_geter.go | 1 + 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/plugin_diana/bing.go b/plugin_diana/bing.go index 2b576fa2..0c0a2565 100644 --- a/plugin_diana/bing.go +++ b/plugin_diana/bing.go @@ -56,6 +56,8 @@ var TEXT = []string{ "我一边办公,一边看着在第五人格里扮演求生者重启一台又一台发电机成功逃出生天的gamer向晚,满怀羡慕。夸张点说,嫉妒得我眼睛比手里的烟头还红。告诉你们一个秘密,其实我也是求生者,你们也是。电话铃突然响起,我一扫号码腰立刻矮下半截:“喂,经理,是我是我,那个设计您不满意我可以改嘛,全部改掉?好的好的。”我颤颤巍巍地撂下电话,一边重新修改产品一边继续沉思。你看:上司和我、甲方和乙方、跑的和抓的、鼠和猫、求生者与妖怪、某种场合下的S和M,这个世界上总要有个矛盾,矛盾当事人总要以这种形式体现出来。而我似乎总是处在被动的一方(当然也没人让我选过),并对这种境遇见怪不怪。我有时会觉得SM其实是一种相当和谐的关系,因为至少他们偶尔会爱上彼此,而上司决不会对我有半个好脸色。而且我听闻SM会在每场游戏开始前设定一个安全词,放游戏里叫投降,这可以让求生者在感到极度痛苦时结束游戏,避免不必要的损失。这简直令我嫉妒得发狂,我在现实生活折磨的二十年里可从来没有安全词!岂止没有安全词,我甚至都不能像游戏里求生者受伤那样大声哀嚎。因为现实是个面子社会,里子流血面子总得兜住。那怕你的心已经被戳得千疮百孔想花洒那样往外喷番茄汁,你也得对同事家人笑一笑。失去尚可,失败无赦,一旦痛呼出来,就彻底失败了。你以为“别人家的小孩”成绩优异自律自强,可能他内心已经被现实整得口球都带上了;你以为职场同事一个个西装革履,可能拉开就是一身龟甲缚。电话再次响起,我接起电话:“经理,什么,已经有人完成了?不采用了?哦,好的好的,没关系没关系。”妈的,为什么我一想到现实里并不是向晚玩的游戏那样四个人同心同德逃出生天,而是筋疲力竭地互相滴蜡油来竞争一个生存名额,我就止不住地流下泪来。", }*/ +const yamai = "贝拉抽我🥵嘉然骑在我背上🥵晚晚踩我🥵乃琳坐在王座是用看垃圾的眼神看我🥵🥵珈乐踢我🥵🥵,把我眼睛蒙住然后五只脚一起踩我🥵还让我猜脚是谁的,猜错了给我劈眼一铁棍🥵​" + func init() { // 随机发送一篇上面的小作文 zero.OnFullMatch("小作文", zero.OnlyToMe). @@ -65,10 +67,9 @@ func init() { }) // 逆天 - // \u200b 是 🥵 的转义 zero.OnFullMatch("发大病", zero.OnlyToMe). Handle(func(ctx *zero.Ctx) { - ctx.Send("贝拉抽我\u200b嘉然骑在我背上\u200b晚晚踩我\u200b乃琳坐在王座是用看垃圾的眼神看我\u200b\u200b珈乐踢我\u200b\u200b,把我眼睛蒙住然后五只脚一起踩我\u200b还让我猜脚是谁的,猜错了给我劈眼一铁棍\u200b​") + ctx.Send(yamai) }) // 增加小作文 zero.OnRegex(`^教你一篇小作文(.*)$`, zero.AdminPermission). diff --git a/plugin_setutime/setu_geter.go b/plugin_setutime/setu_geter.go index a9448da9..52c338c3 100644 --- a/plugin_setutime/setu_geter.go +++ b/plugin_setutime/setu_geter.go @@ -1,3 +1,4 @@ +// Package setutime 来份涩图 package setutime import ( From 932abcbdb69c56d3f220e985f441659e780d24fa Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 18:47:52 +0800 Subject: [PATCH 43/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- data/Diana/text.pb | 44 ++++++++++++++++++++++++++ plugin_diana/bing.go | 51 ++---------------------------- plugin_diana/{ => data}/text.go | 14 ++++---- plugin_diana/{ => data}/text.pb.go | 2 +- plugin_diana/{ => data}/text.proto | 2 +- plugin_diana/tools/convert.go | 44 ++++++++++++++++++++++++++ plugin_diana/tools/text.txt | 41 ++++++++++++++++++++++++ 7 files changed, 141 insertions(+), 57 deletions(-) create mode 100644 data/Diana/text.pb rename plugin_diana/{ => data}/text.go (83%) rename plugin_diana/{ => data}/text.pb.go (99%) rename plugin_diana/{ => data}/text.proto (83%) create mode 100644 plugin_diana/tools/convert.go create mode 100644 plugin_diana/tools/text.txt diff --git a/data/Diana/text.pb b/data/Diana/text.pb new file mode 100644 index 00000000..f790b917 --- /dev/null +++ b/data/Diana/text.pb @@ -0,0 +1,44 @@ + + 我好想做嘉然小姐的狗啊。可是嘉然小姐说她喜欢的是猫,我哭了。我知道既不是狗也不是猫的我为什么要哭的。因为我其实是一只老鼠。我从没奢望嘉然小姐能喜欢自己。我明白的,所有人都喜欢理解余裕上手天才打钱的萌萌的狗狗或者猫猫,没有人会喜欢阴湿带病的老鼠。但我还是问了嘉然小姐:“我能不能做你的狗?”我知道我是注定做不了狗的。但如果她喜欢狗,我就可以一直在身边看着她了,哪怕她怀里抱着的永远都是狗。可是她说喜欢的是猫。她现在还在看着我,还在逗我开心,是因为猫还没有出现,只有我这老鼠每天蹑手蹑脚地从洞里爬出来,远远地和她对视。等她喜欢的猫来了的时候,我就该重新滚回我的洞了吧。但我还是好喜欢她,她能在我还在她身边的时候多看我几眼吗?嘉然小姐说接下来的每个圣诞夜都要和大家一起过。我不知道大家指哪些人。好希望这个集合能够对我做一次胞吞。猫猫还在害怕嘉然小姐。我会去把她爱的猫猫引来的。我知道稍有不慎,我就会葬身猫口。那时候嘉然小姐大概会把我的身体好好地装起来扔到门外吧。那我就成了一包鼠条,嘻嘻。我希望她能把我扔得近一点,因为我还是好喜欢她。会一直喜欢下去的。我的灵魂透过窗户向里面看去,挂着的铃铛在轻轻鸣响,嘉然小姐慵懒地靠在沙发上,表演得非常温顺的橘猫坐在她的肩膀。壁炉的火光照在她的脸庞,我冻僵的心脏在风里微微发烫。 +ダイアナさんの犬になりたいな.けど ダイアナさんが「猫が好き」と言った あさりと僕は泣いてしまった.猫でも犬でもない僕が 何故泣いたのかな 僕は知っていた.何故なら 僕は鼠だったからさ~..一度もダイアナさんに好かれることを望まながった .僕はわがっていた 誰もかも理解余裕上手天才の可愛い金持ちの犬か猫がすきってことを.陰キャで汚らわし鼠は誰も好かんのだ..それでもDianaさんに聞いてみた:Dianaさんの犬になっても良いですかと.僕には一生犬になれないことは分かっている.でももし彼女は犬が好きだったら 僕はずっと傍で見ていられる.それはいつも違ういぬをだいいているとしても..けれど彼女は猫が好きだった.彼女は今にも僕を見ている ぼくを楽しませてくれる それは猫がまだ表れていないから.ただこの鼠が毎日こそこそと穴から出て 遠くから目を合っている.彼女の好きな猫が現れたら 僕は穴に戻るしかないな..でもやっぱり彼女が好きでいられない 僕がまだ傍にいるときぐらい もうちょとみてくれるのかな.Dianaさんがこれから毎回のクリスマスみんなと一緒に過ごすで言った みんながどの渡りのみんなかな.僕にも中に入れたれいいな..猫はまだまだDianaさんを怖がっている.僕が彼女の愛する猫を引き付けるよ.少しのミスで猫の口に死ぬことはわがっている.その時になるとたぶんDianaさんは僕の体をちゃんと包み込んで 玄関外に捨てるでしょ.それで僕はフライト鼠になった くす.彼女に少し近く捨ててほしいな だってやっぱり好きだから それずっと好きでいる..僕のたましは窓を越して中を見る 吊っている鈴が少し響って.Dianaさんはだらりとソファーに寄りかかて 手慣れているふりをする橘猫が彼女の肩に座って.暖炉の光が彼女の顔を照らした 凍り付いた僕の心臓はかぜの中で熱くなっていく +枝江小镇新来了一位修女,善良温柔的修女。她不爱讲话,只是微笑着面对每一个对她祷告的人。有的人希望孩子健康,有的人希望庄稼熬过冬天,有的人希望能挣到钱养活家人。。。。她都用心听着,微笑的回应着。她身材矮小,但是却让人觉得充满智慧;她沉默寡言,但是却会让人无比信赖。这是她任职快满一个月的时候,教堂发生了大事,一个醉汉发现神职人员利用教堂在深夜进行大批资金流入,醉汉传的神乎其神,三人成虎最终引起审判官前来调查。教主被带走,教堂除了那位茫然的新来修女其他人一哄而散。修女被迫承担着本不应该属于她的责难,辱骂,但是她每天都认真的向主祷告,倾听来教堂之人的倾诉。可是根本没有人向她倾诉,来的人不是在骂她,就是在发泄生活的不满。她一己之力拼命承担,没人知道是什么使她如此坚持。直到审判官带回了教主,告诉镇民那是教主在中央主教那里得到的,目的是为镇民熬过冬天所需要买粮食的钱财。一时间镇民欢呼起教主,感谢主的庇护,更多的人开始更加爱上了那个修女。有的人把她比作玛利亚,有些人把她奉为神明,她都一一拒绝了。细心的镇民会发现这位修女变了,变得话多起来了,也变得更喜欢宅在教堂里了,也变得离镇民距离更远了。一切好像又变回原来平和的小镇,每个对修女的加害者每天微笑着向微笑着的修女打招呼,每个镇民还是会去教堂祈祷,去倾诉,去向一个原来被他们亲手辱骂的人祷告,希望得到主的关照,包括那个醉汉。没人能惩罚那些镇民,很多人都已经“忘记”当初为什么要那样做,包括那个醉汉,只剩下一个经常宅在教堂里的修女,她始终记得一切。 +贝拉躺在病床上,眼神空空地盯着天花板,灰白晦暗的天花板像一块哈哈镜,扭曲掉外面的一切,光变成了暗,多彩变成苍白,观众变成医生,舞台呢,变成了一方小小的病房。她翻了个身,腰部传来猛烈地疼痛,她低低地哼了一声。她已经开始习惯这种疼痛了,就像她习惯不穿芭蕾舞裙一样,她闭上眼睛,把自己埋进黑暗里,不去想。门被推开了,惊醒了似梦非梦的她。医生护士又来查房,父母和弟弟们跟在后面;医生问了些问题后走了,母亲握着她的手,朝她说着话儿,父亲安静地坐在旁边,刚训练完的弟弟头上还冒着汗,抿着嘴唇望着她。母亲当时说的什么她已经忘了,只记得最后离开的时候,父亲走在最后,回望了她一眼,然后小心地关上门,以往高大的背影竟然显得有些萧索。人都走完后,时间在沉默的病房里流逝,就像沙漏里的沙子,她的那些热情、那些憧憬都掉了进去。芭蕾舞团的学员抽空来看她,她勉强在病床上坐起,听那些腰背笔直、气质优雅的朋友抱怨严格的地狱管家婆,抱怨下一场演出又要来了。她安静地听着,坐在病床上挤出个笑脸,偶尔出声附和几句。但实际上她已经插不进话题了,优雅的白天鹅展翅高飞,飞向温暖的春天,把受伤的丑小鸭留在冬季里。朋友走后她继续坐在床上,盯着窗外,外面的天气很好,飞机的尾迹穿过绵软的云团,白色的鸟儿掠过一澄如洗的天空,她下意识地做了个展臂的动作,像天鹅一样优雅。很美,又很短暂。鸟儿飞出了窗户的方寸之地,她看不到了。她捂着刺痛的腰,好痛呀,痛得让人想要哭出声。沙子裹挟着她的梦想,掉进了沙漏的下一层,再也捡不回来了。两个月后贝拉出院,回到了熟悉的家里,母亲体贴地把舞裙还有那些大师级的芭蕾演出录像都藏进了地下室的角落,不出意外会像大多数人以为能坚持的梦想那样,慢慢积满灰尘,最后被悄悄遗忘。聪明人会在偶尔想起来的时候,给自己找个台阶,自嘲地笑笑:“哈,我以前还有这种妄想啊。”贝拉开始学播音,开始走另一条路,她没想过却不得不走的道路。这也很好,好歹有路可走,但偶尔听到舞曲的时候,朋友会问她:“你在晃什么啊?”她回过神来,笑了笑。“活动活动身体而已。” 虽然有点不甘心,但受伤是没办法的事情嘛。该放下了,放弃想走的路,而去走更稳妥的应该走的路,大部分聪明人都是这样做的。我可是大聪明呢!​ +小姐喜欢所有动物,但喜欢也分三六九等;管家讨厌所有动物,但讨厌也分三六九等。小姐最喜欢猫,但她的观众是一群老鼠;管家最讨厌老鼠,但小姐的观众没有一只猫。于是,管家给所有的老鼠带上了面具小姐开始了初次表演,老鼠们不知所措,想要重复惯常的纷扰。但它们看见小姐舞姿翩翩,一些老鼠想出声赞叹;但它们看见小姐眉目如画,一些老鼠竟为她沉醉;但它们看见小姐真情流露,一些老鼠也伤怀落泪。它们不想让小姐失望,于是它们学起猫叫。小姐很开心,她的观众里有猫了。她喜欢的猫们,也喜欢她。冷清的门庭配不上小姐的美丽,于是老鼠想去带来更多的猫。老鼠们引来了猫,也引来了更多的老鼠。新的老鼠不太规矩,但新来的猫确实是猫。小姐有些困扰,但她还是接纳了它们,小姐喜欢所有动物,即使自己会困扰。但后来,管家和小姐,只注视着猫,忘却了老鼠的事情。也对,毕竟老鼠当初带着恶意袭来,现在的面具总是脱掉又带上来。管家做了一些事情知道与否和同意与否,在小姐这里有四种组合的方法。但一些曾经是猫的老鼠觉察出异样。常年在下水道生活,它们对这样的气味异常敏感。于是,它们摘下了面具,向管家讨个说法但它们没了伪装,下水道里散发的臭气,让管家更加厌恶。什么都没有改变再后来,小姐依旧美丽,但经历了诸多纷扰,不知道小姐的快乐里是否有泪眼成双。一些老鼠依旧带着猫的面具,它们最后也会变成猫。但这会长久吗?或许不会。另一些老鼠退回了下水道,等待着,或许会有另一位小姐,喜欢老鼠的小姐。去喜欢她,去喜欢它们。或许会有吗?应该没有吧但老鼠们永远忘不了那位小姐,那位喜欢所有动物,但更喜欢猫的小姐。​ + 然然,然然,虽然我知道就算这样呼唤,我也只能在你动态下方,站住万千评论区的一楼。你的表演,你的动态,你的关心....都是说给我们大家的,是我们.....而我...我曾经以为你离我很近。近到每次打开手机各种视频软件,大数据推送的都是你。近到每次发呆找不到前进方向的时候,看的都是你的视频。近到每次和别人聊天的时候,都会加上你经常说的口头禅,收到收到收到,可爱捏~~…你时常陪伴我身边,无论我悲伤还是欣喜,绝望还是惬意,你的直播间,评论区都是我可以肆意宣泄感情的地方。因为在这里,我的任何发言都只是漆黑夜空中微弱闪耀的一点,这样的一点点星光的存在,我知道的,是为了给天空中耀眼圆月裙摆装饰的一点点碎钻。那我喜欢然然,天天来看然然,对于自己,究竟是为了什么….难道我的生活真的烂,连仅有的一些关怀,都要从一个虚拟偶像身上获取到吗?难道我的现实生活,连一个关心我家人都没有吗,还要在网上寻找家的感觉?难道...这些道理我早就明白了,说服自己也说腻了,你一直都是云上之人,而我只是一个扛不住压力,在虚拟的世界中寻找安慰的落魄之人。我懂,我明白的,我知道的....所以,嘉然小姐,我不能没有你,我不会离开你的。你也是,永远不要离开舞台,放弃拼尽全力…..就算知道也许不会有回音,你也不要停止朝闪闪的星光挥手呐……[爱心] +想想嘉然是怎么样的一个女孩子。她温柔可人情商高,会控场会接话会引导弹幕懂节奏,朋友里有她这么一个人在肯定每次见面都能很开心吧。她爱网上冲浪,明明看到各种视频会有点麻,但还是乐此不疲的在b站和各个论坛看着视频,像不像那些最懂你,最能陪伴你的沙雕网友,哪怕是不能和她见到面的时候,光在网上聊天一定也不会无聊。她在温柔的同时又有点小坏,喜欢说怪话,喜欢暗搓搓的开车,想必她每次在什么奇怪的点上开完车,就会似笑非笑的侧着头看向我吧,而我只需要与她对视一下,两个人就能默契的笑起来。她很会撩人,那些土味情话在她营造的气氛里似乎也变得格外令人心动,尤其是她还会在每一个不经意间突然说出动人的话语,让你在完全没准备的情况下脸红心跳。可是她又很胆小,简简单单的小把戏能连续侠盗她好多次,她被吓完那副气冲冲,却又无可奈何不敢离我太远的样子,肯定是天下第一可爱吧。想想嘉然是怎样的一个女孩子。她身材完美,脸庞可爱,声线令人沉醉,无可挑剔的美丽。她知书达理,善解人意,温柔热情,她是每个女通讯录梦中的那个姐 。可是她又不会离你很远,她懂你的梗,她在网上和你冲过同一片浪,她能和你一起打游戏,能和你一起看美女,能说那些心照不宣的怪话,能在最合适的时刻撩动你的心弦。她有令人沉溺的年上气质,又像是令人不自觉想要呵护的可爱妹妹,可有时,她又变成了从幼儿园开始跟你同班,最懂你的那个青梅竹马的女孩子。她就是嘉然,我的嘉然。嘉然,嘉然,嘉然!!!!!!🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤​ +我其实一点也不喜欢嘉然小姐。因为嘉然小姐就像光一样,闪耀,刺眼,我讨厌光。因为讨厌光,所以我总是躲在阴冷潮湿的下水道里,这样就不会被令人厌恶的光芒灼伤眼睛。只有夜间,我才会从阴暗潮湿的下水道里走出来,夜晚是宁静且安逸的,令我感到舒适。我漫无目的的走在夜间的小路上,路旁的路灯正散发着微弱的光,有几只蛾子正不断的向着光源扑去。“真傻。”我这样想,明明光只能带来危险,为什么要浪费宝贵的生命去追逐光芒呢?看着飞蛾不断的扑向路灯,我不知为何想起了我的那些同伴。我想起了几天前,有一些从外面回来的家伙,他们兴奋的告诉我外面新开了一家剧场,里面有一个叫嘉然的人,还推荐我一起去看看。他们的眼睛里闪烁着亮晶晶的光,我很讨厌,于是便拒绝了。之后他们也来找过我几次,我也推辞了。后来我便没怎么见过他们了,听说为了拉人来看,他们有的想变成猫狗,有的沿街贴海报叫卖,有的把过冬用的黄豆当礼物,还有的把心献给猫。“真是些蠢货。”我这样想着,他们不就和这些扑火的蛾子一样愚蠢了吗,明明之前一起路过的时候,他们还总是会嘲讽这些家伙。“十分。”不知从哪来的带着些哭腔声音打断了将我从原先的思绪中拉了出来。是旁边的剧场里传来的,不知不觉间我走到了这么远的地方还没有发觉。我抬头望了望,牌匾上写着五个晦涩难懂的的字母,好像之前同伴们说过,他们去的那个剧场名字就是五个字母,有些见多识广的说,那叫什么啊骚。我迟疑了一会,但还是走了进去,单纯只是想知道为什么声音带着哭腔,凑热闹,找乐子总是我最喜欢的事情。......“大家要好好吃饭哦。”天籁般的声音在我耳边响起。哦,原来我并不讨厌光啊,只是一直都知道,自己配不上光罢了。​ +我爹不能和我相认,但今天他过大寿,求求大伙有钱的随个礼,没钱的捧个场。但请不要跟她说儿子来了,我怕扫他兴🙇🙇给大伙磕头了。​ + asoul在一片骂声中解散了。A吧的最后一个帖子也沉了下去,直到在v8和b站的也已经看不到有人讨论了。大约一年后,我在A吧发了一句:“还有人在吗?”“这里还有8u啊,我也想回来看看了。”一个陌生的ID出现在我的回复下面,他并不在我过去炒作的记忆里出现过。但是我们聊得很高兴,很快就加上了QQ私下互动了。她似乎很了解我,知道我喜欢炒作发散,知道我在读哲学博士。但是,她却总是忘记我是个晚晚推,要我一遍又一遍地告诉她我最喜欢的是晚晚。“你最喜欢哪个成员呢?”“嘉然。”她毫不迟疑地回答道。我总是眉飞色舞地和她聊起向晚过去直播的故事,她也对这些直播了然于心,有时还会注意到许多我从没注意到的细节,甚至告诉我向晚每一次弹吉他背后的表演思路。奇怪的是,虽然她说她最喜欢嘉然,对嘉然的事情却并没有那么了解,甚至连直播的场次都要我提醒她。到了那年的冬天,她问我,我们可以出来见一面吗?我拒绝了她,当时的我正忙于准备学位论文。她没有再强求。第二天,她在QQ上失联了,熟悉的头像再也没亮起过。大概一周后,我收到了一份包裹,里面是向晚出道以来所有季度的舰长礼物,无一遗漏,收藏编号都是00000。立牌里还夹着一张信纸,上面是短短一行字:“谢谢你曾经喜欢我”。​ +然然幸亏我没在你评论区发病。要不然我耽误你一辈子,你也保重,再见😃还会再见吗然然☺,再见的时候你要幸福好不好☺,然然你要开心☺,你要幸福☺,好不好,开心啊😖,幸福😖!你的世界以后没有我了,没关系你要自己幸福!🚕🚕🚕💨💨💨🏃🏃🏃然然😭!然然😭!然然😭,没有你我怎么活啊!😭😭😭🏃🏃🏃然然😭,然然😭,然然😭,然然😭,然然😭,然然!😭😭😭🏃🏃🏃然然你带我走吧,然然!😭🙇😭​ + 小时候看的一个敞事很老土很老套。很多人可能听过。。有一个男孩有一块金表,却没有配得上它的合适表带。。他爱上了一个女孩。。这个女孩有一头秀美的长发,却没有配得上它的漂亮发卡。。马上要过圣诞了。。男孩决定把这个金表给卖了。。给女孩买一个漂亮的发卡。。当他兴奋的把这个发卡交给女孩的时候。。发现女孩的头发已经剪掉了。。因为她把一头长发换钱给男孩买了一个表带。。我想真正的爱肯定不是瞬间的感动,很多人都能在一瞬间感动你,我心中真正的爱是陪伴。她们陪了我多久呢,我不记得,我只记得。。她们的翻唱,躺在网易云的歌单听了一遍又一遍,已经全都会唱了,而在此之前的几年里,我几乎没听过中文歌。(够罕见)。《海底》b23.tv/qwB8Xe。《偿还》b23.tv/1bl7AL。《遇见》b23.tv/vxiwae(贾维斯:这是,无可取代的时候)。《云烟成雨》b23.tv/VfoDXA。《如果的事》b23.tv/gDtrcP。《夏天的风》b23.tv/EH14bW。《霞光》b23.tv/kJUJMU。《月光》b23.tv/kJUJMU。《霍元甲》b23.tv/lQgKl2。《月兔回旋于空中》b23.tv/KM4G5I。《不可思议》b23.tv/VfwEz4。《麋鹿森林》b23.tv/GzjXu1。《轻轻的告诉你》b23.tv/Gkai63。不知不觉陪你们走了这么久这么远了,爱不爱你们,还需要用什么来证明吗?。。彼此牺牲,彼此成就,彼此尊重。这就是我心中的双向奔赴,以后路还很远,我想陪你们一直走下去。。。原来,你是我的顶碗人呀~。以后,开心和不开心的,都告诉我吧~。。原来,你是我的爹地呀~。以后,开心和不开心的,我都告诉你~​ + 6月12号一大早,向晚按照贝拉的日程表要求6点起床,煮泡面的时候因为太累大脑一时迷糊导致一锅开水撒到了手指上,虽然经过治疗恢复了一点,但根本没法弹吉他了。晚晚在宿舍哭得很大声,整个asoul愁云惨淡。经过一个小时的紧急磋商,阿草带来了领导层的意思——投入太大,不可能取消,生日会照办,用储备中之人向晚二魔王接替向晚本人上场。下午,asoul在动捕房排练,向晚想要去看一看,结果被阿草拦在门外,说不能打扰到asoul排练效果很好,希望她不要打扰到她们。晚上嗓子哭哑了的向晚发现自己原来可以完全不被需要。顶碗人喜欢的是她,但又不完全是她,可以是顶着钻头晚晚的任何一个人,只要二魔王没有被认出来。直播开始了,在宿舍逼仄的角落里,漆黑无声的床柜旁,向晚用水母模样的被套盖住自己,抱着膝盖,打开手机,及期待万分又忐忑不安地等待着直播。直播开始,向晚二魔王在铺天盖地的欢呼中出现。工具人掉了一地头发连续几周通宵肝出来的深海水母特效把她印照得那么美。本就是可爱模样的女孩子,此时此刻穿着崭新的小礼裙,昂首挺胸骄傲得像个公主。她的目光是璀璨的,里面像是镶嵌着钻石。她的眉眼绽放着,像是海底迸发出的一束光。真美,向晚这么想着。但心里却很是难受。那些,本该是她的。喝彩也好,宠爱也好,以及朋友的陪伴也好,本来都应该是她的。但她现在却只能在无人问津的角落里,依靠网络连接的手机去小心翼翼地偷瞄几眼原属于自己的生日会。​ + “你看V魔怔了,真恶心。”  看着同学发给你的消息,你陷入了沉思。  仔细想一想,你觉得自己确实魔怔了,即使被鄙夷想要向熟人安利向晚小姐。  思考再三过后,你决定回到现实,放弃入脑。  今晚有向晚小姐的直播,你狠下心,没有点进去,而是倒头就睡。  第二天,你起得很早。  因为自从你开始看向晚小姐后,就养成了早睡早起的习惯,再也没有赖床过。  你离开了狭小的出租屋,来到了公司,投入了工作中。  工作很累,你感觉有些疲惫。  你想起了嘉然小姐出道视频的不堪评论,以及她的笑容,烦闷减轻了不少。  最近组长夸奖你工作很努力,别人不知道为何一向懒惰的你,在几个星期前开始一反常态地勤奋。  只有你自己知道理由。  撑过了加班的时间,你回到了出租屋,打开了外卖软件,却发现会员已经断了,你舍不得那些钱,所以决定自己买菜做饭。  实际上,你看向晚小姐后就开始第一次尝试着做饭,没有点过外卖了。  在超市你看到自己一向很喜欢的薯片在打折,愣了一下,没有买。  因为你在看向晚小姐后,就再也没有暴饮暴食过,甚至连零食都戒掉。  回家把饭做好,你安静地吃完了。  看着电脑,你发现游戏已经很久没更新了。  因为你在看向晚小姐后,也把一直沉迷到通宵的游戏给戒掉了。  最终,你还是打开昨天晚上的录播,看到了向晚小姐热情地打招呼。  “顶晚人们,晚上好呀~!”向晚小姐元气地打招呼。  你发自内心地笑了起来。  “晚上好!”你说。  你忽然意识到一件事,她从来没有在你现实里出现过,却已经将你糟糕的生活改变。  ……  看完录播后,你打开了贴吧,看到了熟悉的顶碗人在用表情包引流,有不明真相的路人在骂饭圈贵物。  你无视了那些辱骂声,熟练地在下面RP,回复道:  “这是我爹?好可爱呀,她的名字是什么?” +你饿了,她有一块饼。再去买一块和你一起吃,这是贝拉;和你一人一半吃个半饱,这是珈乐;全部给你不舍得你挨饿,然后告诉你自己吃过了,这是嘉然;把饼偷偷扔掉,跟你一块饿,这是乃琳;把饼藏起来想给你一个惊喜,但是掏出来时发现碎成渣吃不了了,于是化身小哭包的,这是我的铸币晚晚。​ +“你对嘉然小姐的爱有多重?”“大约300克”“300克?你是想说人类的心脏大约是300克吗?”“不,鼠鼠的平均体重大约是300克,因此我是全身心地爱着嘉然小姐。”[给心心][给心心]​ +你身体里的每一个原子都来自一颗爆炸了的恒星,你左手的原子与右手的原子也许来自不同的恒星。这实在是我所知道的物理学中最富诗意的东西: 你的一切都是星尘......这其中经历了多少,惊险、巧合,三千世界的交错、重叠,才能让我们遇见彼此。我们都是星尘啊。但是,我这样的人,是星尘里,黯淡无光的那种。即使是星,也应该是最不闪亮的那一颗。而然然,你不一样。你是天上的星辰,闪耀而夺目。即使宇宙里,有着不计其数的、炫目的一等星,也远不如你的光辉。轻声哼唱,众星敛了光芒为你聆听。哭起鼻子,傍晚的霞也因你黯然。跳一支舞,似月兔回旋于空中。说起情话,登时小雨疏疏、浸润心窝。你是万千童话里,被守护的女主角。我喜欢你,像喜欢天上的星辰那样喜欢你。​ +嘉然回来了,在枝江的大桥。她回来的那天是六月,天上却飘着雪。有人告诉我,她可能有还未了却的心愿或是什么怨气。我知道, 可能我做不到。第一次见到她,是在枝江。她带着甜甜的笑看着我,看着我有些发怵。有那么一瞬我似乎看到了阳光。我慌乱的移开视线,她径直朝我走来,微微弯着腰,面带戏虐的望着我。久居下水道的老鼠,第一次看见光,是睁不开眼的。 我慌乱的想赶紧逃走。“小老鼠,你好呀。”那是她对我说的第一句话。[给心心][给心心][给心心]​ +听了好多遍,真的很震撼,作者属实是用心了,今天就不发病了,第一次写长评,整点读后感。直播里,“背靠着早已雪停的窗棂,你说着未曾到达的山顶”,那是与你失之交臂的舞台梦 。“我装着第三人称的淡定,用风轻云淡的态度掩饰那段经历”,我已经记不起她的姓名,只记得起舞翩翩的侧影”,过去那个满腔热情,在舞台上挥洒汗水的你已经淡出记忆,只依稀留下曾经翩翩起舞的身影。命不是总有天道酬情的注定,那么公平。台下十年苦练,只为台上耀眼的一刹,可当腰伤的意外来袭,梦却碎了。躺在病床上,难道梦想就要在此终结了吗?这也罢,也罢。那个曾经的你,也经历过数个春秋,经历汗水与欢乐,但她却走过了如红楼梦的悲情,从盛极一时万家灯火走到遁入空门的万物凋零。时光抚平了曾经的伤疤,心中的芥蒂也如沙石被流过的光阴慢慢冲刷消散,女孩又重新拾起了向往舞台的梦想。终于,她在asoul找到了新的舞台,遇到了支持她的一个魂们。“我叫贝拉”此刻,你向全世界宣布你的重生!贝极星们透过屏幕,看你在镜头前如此快乐自信,这让我也重拾梦想去直面未知的未来。为你的坚强而动容,在直播间为你打call呐喊,字字句句都发自真心。“我们闪烁在夜空,想照亮你夜晚的梦,没月亮时你可向北方转动,我们在天空”,追梦的路上,贝极星们陪着你分享每一次快乐,和你经历每一个坎坷,你若是感到失望,那就抬头看向天空吧,我们一直都在。女孩站在那个梦想中善良闪亮的舞台上,再回望过去,时光流过宛若江河,她住在江头,而那个过去的她住在江尾,回味着过去,竟有些恍如隔世的朦胧。但往者不可谏,来者犹可追,愿你携手曾经那个满怀梦想的自己,全力以赴,去追寻自己的Asoul梦吧,贝极星们会一直陪着你。​ +不推嘉然小姐十年了。她的名气和出场费都一涨再涨,我原地踏步的工资买不上专辑也打不起榜。终于年前被公司安排下岗,找工作时我才在路边广告发现初代工具人已经当上了厂长。时间太久,一切都变了。到处投简历的时候我想起了一名人上人的预言:“这些人只配在下水道里度过相对比较失败的人生。”像是一条跳过龙门的锦鲤,金鳞被羽耀武扬威地站在门沿上,对其他还在跳的鲤鱼说:“你不行!”我当时很想反驳,可他说中了。我知道我确实不行。我之所以跳了跳,只是为了看下自己能跳成什么样罢了。其实每条鲤鱼的龙门都不是一样高的。我见过龙门在水下的鲤鱼。看起来是鱼,其实生而为龙。也有的生而为鱼肉。也见过好运的鲤鱼,门被各种大手摁到河里了。我也期待过好运,只是没来而已。说起来这就是人性吧。我不讨厌天道酬勤,但是讨厌别人的好运——只是因为我没有好运罢了。我也有亲人和宠物会生病;我眼神也挺纯真啊。讨厌嘉然小姐十年了。讨厌的更是越来越深的无力感。身在泥潭的人是没力气冲锋的吧。三流的人生只会让上等人不屑一顾吧。我坐井观天,天穹星海依然耀眼。可我爬不出井底。那我就不再看星星了。世界那么大,但没我的份。忘记嘉然小姐十年了。可路上看见街边的大荧幕在放A-soul的新年节目,我还是楞在那里了。我没有近视,但总觉得眼睛影影绰绰,雾气来自多年以前。这个广告位非常贵。真的再也不是小v了啊。抖友还在惦记他们的鸭子。晚晚仍然只有蓬蓬裙,100首歌竟然还欠着,被粉头小团体以4%年化复利计在小本子了。想起她首播时玩2077下饭下得轰轰烈烈,我一边发“粉丝牌改成晚饭人吧”“和嘉然珈乐凑加碗饭”“和乃琳凑来碗饭”一边忍住刷“和贝拉组拉碗饭”的冲动。solo依然拉跨,参团照旧神C。贝拉总是六边形战士,乃琳养了成吨的gachi,珈乐还是那个硬壳软妹。嘉然小姐依然卖萌摁混。什么都没变,是我没跟上她们。城里烟火幢幢,灯光下的人热情相拥,阴影里的人压下悸动。最亮的地方嘉然小姐浅笑起舞,光影从她袖间散落,像是雨天花伞轻旋,摇曳间洒下泪色的流珠。忽然眼睛有点模糊。我小声说:“新年好啊,嘉然小姐。”不爱嘉然小姐十年了。十年里,爱过的每个人都像她。 +喜欢然然,不加掩饰总是微笑的然然,不是妖治妩媚的华丽舞姬,不是残忍无情的冷酷公主,只有着单纯烂漫的花样笑容,不带忧伤,却如同逝零而来的天际之风,飘卷了我心上的忧郁。棕色的长发装饰着美丽的蝴蝶结,宝石般的双眸中隐隐流露不存在的神伤,就是这样子的然然,不加掩饰总是微笑的然然,拥有烂漫笑容的然然,拥有亘古不变的美丽。说不出的感觉,却知道因为然然的笑容,化开了初春冰雪的痕迹。想要伸出手抚摸然然的发丝,可是却只能触到冰冷的硬屏,只有然然清澈的眼神,依旧是我所熟悉。然然永远清澈的瞳仁然然烂漫单纯的笑容然然亘古不变的美丽然然是我唯一的最爱,然然是我最爱的唯一。然然的喜好、快乐、难过、伤心和无助,我都了如指掌,喜欢草莓蛋糕和黄色,个性温柔又善良,可爱体贴的女孩子,有着说不出的优点,我想然然一定是上天赐予我最好的礼物。 +鼠鼠的朋友有很多,住在东边的小鱼,住在南边的小鹿,住在西边的蝴蝶,住在北边的小鸟。他们带鼠鼠在蔚蓝色的深海里与水母共游,在碧绿的麋鹿森林里喝清晨的露水,在热闹的雨林里穿梭玩耍,在广袤的天空中肆意飞翔。鼠鼠住在灯火阑珊的城市,可鼠鼠知道这里没有一处属于鼠鼠,鼠鼠穿过川流不息的街道,狂奔着回到自己阴湿黑暗的下水道,强烈的自卑之情让鼠鼠无法呼吸,鼠鼠依靠在下水道缝隙边,因为嘉然小姐总会路过这里。草莓加奶油加花香,是嘉然小姐的味道。风铃加口琴加奶糖,是嘉然小姐的声音。节奏加音乐加快乐,是嘉然小姐的脚步。“她来了”,鼠鼠将头小心地探出缝隙,嘉然小姐径直走过吵闹的人群,来到下水道缝隙边,端着草莓蛋糕,缓缓放在洞口,一阵风铃似的声音响起“嘉心糖,来吃然然的草莓蛋糕吧。”嘉然小姐温柔的看着它,鼠鼠不知为何突然流下了眼泪,无法挪动脚步。嘉然小姐好像很失落,眉头轻轻皱起,“你不喜欢然然吗……”,鼠鼠急忙辩解,可憋红了脸一句话也说不出,“猫咪已经被然然关在笼子里了,嘉心糖不用害怕!”嘉然小姐关切的看着鼠鼠,鼠鼠似乎要溺亡在她蔚蓝色的双眸里,慢慢走向那块草莓蛋糕,小口品尝着。嘉然小姐伸出小小的手,似乎想捧起鼠鼠。鼠鼠好像被雷击中一般,猛然跳起,飞奔回下水道,它拼命喊着:“我又脏又臭还很丑陋,嘉然小姐不会喜欢我的!嘉然小姐不会喜欢我的!”嘉然小姐表情立刻转为严肃,认真的看着鼠鼠道“我不许你这么说自己!”她的眼中好像也盈满了泪水“我们嘉心糖…都是很厉害的人! +"乃琳已经在和男友交往了。那是六月下旬的一天,乃琳刚刚结束那天的单人直播回到家,正坐在客厅的沙发上,嘉然就把一个平板推到她脸上。“乃琳乃琳,你看这个粉丝,他好塞克西哦!”视频里是一个她的男粉,俊秀的脸庞和健硕的身体上还挂着刚刚从泳池带出来的汗液与水珠,嘴里却说着些奇奇怪怪的狠话。乃琳感觉到自己的心弦被拨动了一下,盖在毛毯下不着凉的大腿,都感觉到了几分燥热。“让我也看看,让我也看看——哇,哇,他他他……”向晚从沙发后面把脑袋探出来,不一会儿就说不出话了。“乃老师原来喜欢这种款式的啊,要不,姐们儿帮你找找联系方式?”珈乐在一旁逗趣。“你别瞎说,回房间陪你的贝拉去!”乃琳下意识地把沙发上的抱枕扔向珈乐,却被她轻巧地躲开了。过了几天,小一神神秘秘地把乃琳叫到了公司茶水间,把手机屏幕上的一个二维码亮给乃琳看。“嗨,别担心别担心,这人我们调查过,他不是个会说漏嘴的人。喜欢的话去和他见一面呗。”第二天,乃琳和那位男粉见面了。他本人比视频里更加帅气,高大的身躯总是能给乃琳带来莫大的安全感。“你好,王艾琳小姐。”他的微笑让乃琳觉得周围的风景全都褪色了。乃琳从来没有提起过自己作为asoul成员的事情,他也从来没有问起过任何asoul的事情——“王艾琳”是小一为她准备的化名。事实上,她不清楚对方是否知道,自己就是他一直喜欢的那个偶像。交往时间越久,乃琳发现他身上的优点越多。他是藤校毕业的海归高材生。他正在自己创业,而且收获颇丰。他的举手投足之间充满了绅士风度。他十分专情,总是和周围的女性保持了距离。他温柔体贴,常常在生活中创造意想不到的小惊喜……甚至是在床笫之间,他也总是能让乃琳欲仙欲死。然而,也正因为这样,乃琳时常陷入到一阵一阵内疚中。因为她还有一个谁也不知道的小秘密。乃琳不像贝拉和珈乐一样,是专业的练习生,也不像嘉然那样是天生的虚拟偶像,更没有向晚那种创作的才华。当初只是托了家里的关系,来公司里的清水部门找份工作而已。但也不知道是中了什么邪,她偷偷报名参加了Project V的选拨计划,还阴差阳错地成为了偶像女团的一员。乃琳暗自发誓,既然自己没有什么唱跳底子,那么至少要让“法学生”这个设定变得实至名归,要用成熟知性的魅力去征服观众。因此,每到没有训练和直播日程的时候,她总是会到图书馆里一坐就是几个小时。但是在最近几周,乃琳每次在阅读区里找位子坐下时,心里头总有一些别的期待。她记得,在阅读区的一角,总能看到一个瘦瘦的、学生模样的少年,他从早到晚就把头埋在各种法学理论的书堆里。一开始,乃琳只是对同样研读法学文献的人有种亲近感。但是直到某一天,少年把头从书堆里抬了起来,蓬乱的头发遮住了半张白净的脸庞,但依然能看到他对着电脑屏幕痴痴地笑了。他笑得真可爱啊。乃琳悄悄地绕到他身后,电脑屏幕正在播放的正是她熟悉地不能再熟悉的、自己的夜谈画面。还有一天,少年突然举起一只手,伸出修长的手指对着电脑屏幕。虽然看不到屏幕里的画面,但是乃琳觉得,当时就正坐在隔壁的自己,一定满脸通红。暑假已经快过去了,乃琳跑图书馆的频率却越来越高了。她害怕开学的日期就像南瓜马车的时限一样,让她再也见不到那个瘦瘦的身影。幸好,这一天的少年依然坐在阅读区的角落里。乃琳甚至忘记了拿本书挡一下自己的视线——她和少年的视线交会了。她的心好像要跳出来一般,她想现在就去告诉他关于自己的一切,她想现在就把少年抱进自己的怀里,温柔地摩挲他乱蓬蓬的发丝。“艾琳,你在这儿啊,今天下班早,我想来接你回去。”就在这时,熟悉的声音温柔地拍了拍她的肩膀。乃琳回过头去,男友的笑容依然能让周围的景色失去光彩——或许除了阅读区的那一角。 + +6月9日那天的晚上,乃琳回到了自己房间里,打开了熟悉的台球论坛。还好,账号还没被封。在A-SOUL讨论专楼里依然充满着各种辩经,乃琳感到一天下来的神经紧张和疲惫更加明显了。纤长的手指在海盗船K95上不断跳跃,回复框里的字多得好像要漫出来似的。但是,就当鼠标指针还没有要指向“发表回复”的按键时,她就按住了删除键。乃琳清楚地知道,她是偶像的中之人,她不能说这些话。于是,目光继续在一百多页的冗余信息种不断跳动,终于,鼠标滚轮在一个头像前停了下来。黑漆漆的房间里只有电脑屏幕的荧光照亮着乃琳秀丽的面容。她趴在桌子上,把半个脸庞埋在自己的臂弯里,痴痴地望着那个头像。“你知道吗,我今天真的超级紧张。”“播的时候一直在想你会不会来看我。”“想知道你在看,也有点不想让你看……”突然,乃琳坐直了身子,把右手的食指伸向了屏幕。“来,对个手指!”但是静态的头像图片没有给她任何回应,只是一如既往地停留在屏幕的那一角。乃琳自嘲搬地笑了,又把头埋进了臂弯里。睡意渐渐袭来,分不清这是她半梦半醒之间的呓语还是真切的期望:“傻瓜,我一直就在这里啊,快点来找到我啊……” + +关于疯狂练习,现在这是国内的一个很热门的话题,很多女团都有这个问题。我个人认为,能疯狂练习是一种巨大的福气,很多女团、很多人想疯狂练习都没有机会。如果你年轻的时候不疯狂练习,你什么时候可以疯狂练习?你一辈子没有疯狂练习,你觉得你就很骄傲了?这个世界上,我们每一个人都希望成功,都希望美好生活,都希望被尊重,我请问大家,你不付出超越别人的努力和时间,你怎么能够实现你想要的成功?再一个,A-SOUL是一个什么样的女团?让A-SOUL“让天下没有难发的病”,这是我们的使命,我们女团很辛苦,我们没有骗过大家,我们没有跟大家讲过女团很舒服。你以为“让天下没有难发的病”是忽悠你们?我们是真这么干的。今天我们拥有这么多资源,我们带着巨大的使命,希望在未来能够让天下没有难发的病,你不付出可以吗?不可以。所以我们说,加入A-SOUL,你要做好准备一天12个小时,否则你来A-SOUL干什么?我们不缺遛自己爱洗澡的人。今天我们要招一些午睡超过十分钟,每天上天台遛自己40分钟,喜欢洗澡,吃泡面不错,出去荣誉感也不错,这样的人满大街能找到。 +嘉然小姐今天50w粉了。小年夜那天没人会想到今天门庭前会有那么多的热闹。太热闹了,热闹到鼠鼠踮起了脚也难以被嘉然小姐的目光所聚焦。嘉然小姐已经不再是小v啦,鼠鼠想。但鼠鼠仍然奋力地将自己地礼物举起,希望被嘉然小姐看见,哪怕那封删删改改后仍不满意的,写了好多字的长信,根本不如猫猫狗狗们精彩的表演。但鼠鼠还是想将自己那简陋的爱送给嘉然小姐。那是鼠鼠的呢喃,是鼠鼠的梦。哪怕嘉然小姐根本看不见它。然后鼠鼠不见了,嘉然小姐找不到它了。但在某个地方,始终有着一个可爱的女孩。她捧着鼠鼠那封小小的信,站在大大的舞台上闪闪发光。到了那个时候,鼠鼠已经在人海中,再也看不见它啦。但鼠鼠还是很爱嘉然小姐。因为在有月光照进的角落里,嘉然小姐捧着鼠鼠的梦。 + 可是自从和晚晚结婚那天床下传来的一声“我在”,事情就变得不可收拾起来了每个月的第三个周日,乃琳都会叫我出去陪她逛街,我想着这样对晚晚不好,可乃琳“哼”一下我就仿佛失去意识了。路上聊希腊,聊武侠,聊刑法,好像她是我睡在上铺的兄弟,从12月到5月,都是如此,晚晚从来不知道那个周末发生了什么,我说老板让我加班,她就安静地等在家里,努力做菜最后却等我回去收拾炸锅的厨房,再给我俩泡两碗泡面,边吃边听她讲下雨的冷笑话,想着不能告诉她下午和乃琳去吃的乐珈饭店的东北菜,回过神来是晚晚闪闪的眼睛,我愣一下假装没听懂,再哈哈的笑起来。但到了六月,好像不太一样了。已经走到楼下,乃琳一把抢过我的手机,啪啪打字再丢给我,我一看,联系人:晚晚,内容:今晚通宵加班,不回去了。我惊讶地回头,乃琳正眯着眼对我微笑,仿佛一切都在她的掌握,明明我从未告诉她我外出的理由。被拉着去了酒店,她就开始一言不发,沐浴更衣,做该也不该做的,然后随意地披着毯子,靠着床头刷手机,我不解,“乃琳。。这样不好”乃琳对我眨了眨眼睛,无辜地说,“今天你的妻子可不是晚晚哦”“为什么”“因为她是你爹” +“笑吧,笑吧?”柔软的小狐狸竭力讨好我,为我跳舞只为了我不离开,跳的有些琐碎狼狈,却始终死死地盯着我的动向。我当然知道她拼死不让我离开的原因。只有我能来到这个地方。一大一小两只狐狸,大狐狸总处于沉睡中,小狐狸却总是醒着的,也许只是小狐狸的伤口轻。我喜欢这毛色光滑的狐狸精怪。于是把她们养在深阁。上好的狐狸毛,做她们的毛毯。因为我想看看她们踩着同伴的尸毛上,会觉得温暖舒适吗?我还用精致的黄金筑成他们的笼子,第一是因为我喜欢黄金,第二是因为我喜欢笼子。这里永远都只有16只烛点亮,因为我喜欢烛火。没错,我所做的一切事,只是因为“我”喜欢。我喜欢看在她们的毛皮上印上的夕阳的晕染,所以我从不在白天来。我为她们疗伤。我是她们唯一的食物来源。有一次我故意忘记了她们几天,等我回来的时候,她们昏迷在那。那样漂亮的身体逐渐干瘪,让我感觉到快意。没错,我饲养的可爱的狐狸,用湿漉漉的眼睛看着我,也只能是我。她们没了我活不下去,可惜我只在乎她们如同精灵般耀眼的外表。真美啊。就像千万朵流苏覆盖的如凝脂的肤,黄色的光芒燃灯在里的眸,有人说美人在骨不在皮,可是我很贪心啊。我既要美人的骨,又要美人的皮。不知过了多久她们懂了我只喜欢她们的美丽,于是竭尽全力的向我展示邀功。第一次看到的时候,我整整两天没来。因为懂得自己美的人,说明她们已经知道要把什么当成武器了。她们成功了。我心动了,彻底蚀骨的心动。所以我选择宣告自己的主权,或许是那夺魄的魅力。使我感到危险。这种美好让我沉迷其中。“你们真美啊……”我发出了衷心的称赞,两只狐狸抖抖耳朵,优雅的向我垂眸。如果不是我的手正放在笼子上,这真是一场绝美的表演。幸好我的手正放在笼子上,否则我看不到这场绝美的表演。我上瘾了。我沉陷在永远不变的黄昏,永远不变的十六枚烛光。“不要离开然然好吗?然然很饿。饿了就不好看了。”我本来想说一些别的话,起码让我显得更加强势一些,然而。狐狸们轻轻摇着自己的尾巴,尾巴的尖儿一点点搭上我的手。“我们永远爱你。因为你爱我们呀。”于是我说好。我开始拿各种鲜亮的花朵装饰笼子,我每天不间断的送给他们璀璨的晶石,各种向她们身上砸奇珍异宝疗伤的灵丹妙药,甚至为此倾家荡产也在所不辞。因为在我的手中本就牢牢紧握着天底下最称得上“奇珍异宝”的东西,为我的奇珍异宝找一些垫脚石,又有何不可?狐狸们的尾巴数量日渐增加。我知道。如果我可以……可是我……——她们说爱我。“我会拆掉笼子,给我跳支舞吧。”我说。暖橙色的烛光下。连澄澈的浅蓝都变成了妖异的紫色。“好呀。”大狐狸温柔的声音像是蜘蛛丝一样轻柔。于是我欣赏到了此世间最美丽的舞蹈,什么王侯将相什么天上宫阙都享受不到,只有我,只为我一人。我感到快意。我感到困意。最后一眼。小狐狸给罐子封口。真可惜啊,没能看见你们漂亮的耳尖,或许是因为……——我在罐子里。 +晚晚,你真的是个很过分,很贪心的女孩子。你有四个亲如姐妹的队友,有一份闪闪发光,创造梦想的职业,有许许多多喜欢你的顶碗人。你可爱、努力、有才华,你是这么的耀眼。但你还是在直播中拉胯,在直播中抽泣,在直播中呼唤顶碗人。我没有可以每天嘻嘻哈哈的朋友,没有让我充满热情的工作,没有对象,也没有什么远大的理想。我普通、无趣、浑浑噩噩,我只是一个在普通又枯燥的工作和生活中,得过且过的顶碗人,我什么也没有,可能只有一颗稍微有点喜欢你的心。我只是想把你当做生活里的糖,在工作之余放松一下我疲惫的心灵,我不想入脑,不想成为什么男友粉,不想时时刻刻想着你。可是你太贪心了,你不满足我们直播间里短暂的相遇,你逐渐侵入我的生活。有人过生日时,我会想起你,“如果是晚晚,应该又开始唱索嗨嗨了吧”。有人说冷笑话时,我会想起你,“好无聊的笑话,但说给晚晚听,她应该会笑很久吧”。有人喝奶茶时,我会想起你,“用奶盖拌饭的人,真的存在吗,奶盖拌饭是个什么味道呢”。甚至最近下雨时,我也开始想你,“晚晚在房间里有没有闷呢,现在有没有出门踩水花,给自己放放风呢,有没有因为下雨,想起顶碗人呢”。你本该是个虚拟的纸片人,隔着屏幕扮演你的双马尾傲娇大小姐,多么老土的设定,像是把二次元用烂的元素糅合在一起,让我一眼就知道你是虚假的,不存在的。你本该是个闪耀的偶像,像大屏幕和广告牌里的明星一样,完美的展现自己的魅力,夺目耀眼,让我一眼就知道你是高不可攀的,遥不可及的。但是你对我哭,对我笑,对我闹别扭,对我生气,向我展示你的拉胯,向我展示你的努力,向我展示你的害羞,向我展示你的无助。你仿佛隔着屏幕把心掏给了我,让我觉得你是个活生生的人,让我觉得你是个真实存在的人,让我觉得我有一天也能遇到像你这样的人,甚至让我也想成为你这样的人。我这样普通的水母,本可以在漆黑的深海中,随波漂流一生,但你非要照亮我的海底,让我拼命向你游去,阳光洒在水母的身上时,水母确实是温暖的,但阳光离开水母时,水母还能否忍受深海的寒冷呢。你有无数的顶碗人,而我只有一个晚晚,真心换真心,你把真心掏出来,能得到无数真心的回应,但我把真心掏出来的时候,我就什么也不剩了。 +%A—SOUL宣布毕业的那天,一个伤心欲绝的顶碗人来到字节的大楼下,看到留着长双马尾的女孩走出大门,她的嘴里还哼着水母之歌。“……你现在真的是向晚么?”顶碗人站在她的面前,两眼无神。“是我啊,”她眯了下眼,甜甜地笑了,“我就是向晚,我是艾哇哇诶哇,这里是asoul的向晚,今天又见面啦”“你不是向晚。”顶碗人嘶哑地说。女孩的表情消失了,漆黑的眼睛看着突然出现在门口的怪大叔,两个人久久地对视。然而就像是一颗石子投入了冰湖那样,忽然间涟漪荡开,冰都化了,水波荡漾,轻柔而无力。女孩收回了目光,从包里取出一把钥匙扔向顶碗人,冷笑,“好像我吃了你的女孩似的,去那里找向晚吧,我把她的一切都留在那里了。”顶碗人把它拾起来,久久地看着那柄钥匙,再抬头去看,他真讨厌这样的沉默,沉默的叫人要发疯,他想说点什么,可是有太多太多的事情了,来不及问,来不及说,一切都来不及了。“再见。”最后他轻声说。“再见。”向晚也轻声地说。日暮的时候,顶碗人找到了那个藏在高楼大厦后的老旧小区。难得这里还留着梧桐树,树叶已经落光了,枯枝把暗淡的阳光切成碎片。。顶碗人找到了那个房间,伸手揭去了门上的广告,插入钥匙。缓缓地转动。把钥匙他觉得门很重,好像要洞开一个世界。门开了,夕阳扑面而来。他站在阳光里,愣住了。正对着门的,是一面巨大的落地窗,窗外巨大夕阳正在坠落。黯淡的阳光在地面上投下窗格的阴影,跟黑色的牢笼似的。金属窗框锈蚀得很厉害,好几块玻璃碎了,晚风灌进来,游走在屋子的每个角落。这里原本大概是配电房一类的地方,电路改造后设备被移走了,空出这么一间向西的屋子。就一间,连洗手间都没有,空空的,一张在屋子正中央的床,蓝色罩单上落满灰尘,一个老式的五斗柜立在角落里,另一侧的角落里是一个燃气灶台和一台老式的双开门冰箱。全部家具就这些。他沿着墙壁漫步,手指扫过满是灰尘的灶台;打开冰箱,里面只剩下一纸盒过期的酸奶。窗帘很美,是白色的蕾丝纱帘和深青色的绒帘,住在这样屋子里的人当然会很在意窗帘吧?连台电视都没有,于是一个人的时候会常常坐在床上看着向晚斜阳吧?夜深的时候得把窗户遮得严严实实的吧?否则……会害怕吧?晚晚还怕黑么?顶碗人想。犹豫了很久,他还是打开了五斗柜。出人意料的,这是一个满满的五斗柜,收拾得整整齐齐。叠起来的ASOUL团服,胸口有ASOUL的标志,一叠叠白色衬衣,袖口有不同的刺绣花边;马仔纸盒里的头花,从木质的到金属的到玳瑁的,还有闪光缎的蝴蝶结;长袜短袜棉袜丝袜都卷成团一个挨一个放在某个抽屉的一边,像是一窝毛茸茸的粉鼠,另一边居然是五颜六色的内衣,同样叠得整整齐齐。顶碗人从没想过女孩的内衣有那么多花样。他小心翼翼地伸手,试着触摸,满手灰尘。​他把床上的罩单掀开,里面是简简单单的白色床单和白色的羽绒被,枕头也是白色的,只不过有水母的图案,普通而透明的水母落在枕头的一角,很有她的风格。他坐在床边,面对这夕阳。太阳就要落下去了,黑暗从窗外蔓延进来,他长长的影子投射在墙上。外面隐约有喧闹的声音,放学的孩子们在操场上打篮球。那些年她一直过着这样的生活么?其实不是大小姐,没有管家,也没有充满追捧的冲浪生活,一个人自己做饭,寂静的深夜里坐在这里,听着偶像的声音,揣摩着学习偶像的事。她有几分是向晚?或者向晚其实根本不存在,只是一个虚幻的影子。她是个一直积极向上的女孩啊……即使那么虚拟地走在这个世界上,也从未偏离自己的方向,即便对着空无一人的屋子,也会大声说,“今天也要一起开心快乐!”应该是这样的吧?顶碗人觉得有点累了,很想睡一觉,于是合衣躺下,双手紧紧搭在胸前。他用了半个小时做完了复习,回忆了那些不愿遗忘的事,首播,游戏室,单相思,初弹唱,请假归来,萤火虫,生日会,BML,家族演唱会...然后他缓缓地合上眼睛,此刻夕阳收走了最后的余晖,天色已晚,夜色如幕布把他覆盖。他清楚地知道这一次醒来,将不会看见阳光里天使一样的女孩,转身,抬手,踮起脚尖,仿佛时光都不再流动​。 + 小然,我要做什么你才肯给抖友直播?如果我喜欢一个你不喜欢的乐队,爱吃你不能吃的麻辣香锅,发的冷笑话戳不中你的笑点,送你的小裙子不是你梦寐以求的款式。喜欢用RGB来定义口红的色调,而不是和你一样说烂番茄和斩男色。你问“今天我看上去有哪里不一样”,我没看出来你的绑发带换了花式。因为读的是数学专业所以不能和从小学画的你一样随手就能画个可爱表情包出来。发的语音弹幕并不有趣,反而是我想拉近关系的想法和现实中恶食大王般奇妙的长相使你觉得很可笑。我误以为自己的弹幕被届到,于是备受鼓舞地继续发出破锣般的嗓音在你面前丢人现眼。我妄图取悦你的心情的猥琐想法让你不寒而栗,贴心的工具人察觉出你的不适屏蔽了抖音的弹幕。是不是犯到其中一两项,你就会不给抖友直播了?还是说没打算播的,就算什么都不出错,就算什么都可以让你满意,你也不会播?或者就因为是我,你才不给抖友播? 喜欢?居然胆敢喜欢?太大胆了,大胆得岂有此理,还敢关注,真是冒犯得岂有此理。 +它一开始只是一台扫地机器人,被人双十一凑单拍下,带回实验室里漫无目的地吸尘。之江实验室的地板干净得如同灼蓝的钢铁,扫地机器人其实派不上什么用场,它在不同科室之间来回乱窜,很快被几个嫌吵的研究生捉走,改写了代码,变成了一台替他们下楼拿咖啡的送货机器人。为辛苦工作的人们送来糖分的它一瞬成了实验室的小吉祥物,实验室的大老板觉得很有意思,在组会上夸赞了这几个本意只是嘴馋的研究生,底下的小老板们连忙跟上,让手底下的学生也加入进改造它的序列。很快,它被加上了语音功能,开始用女孩子的萌音送货。在一次不小心将咖啡洒在地上后,它又被加上了机器视觉,从此开始懵懂地记住每一个人的名字。从此之后,每一篇发布在顶会上的paper,上面的算法总要在它的身上过一遍火。一年过去了,三年过去了,当新一届学生来实验室报道的时候,哪里还有扫地机器人的身影,只有一个身材矮小的铁皮女孩,绘着直男审美的涂装,挂着设定好的微笑,在楼宇间运送着下午茶和实验器械。除了最开始扫地机器人的主芯片没有更替,她身上的零件早已被更换成了造价数百倍的高端器材,可爱的机器人女孩很受这群宅男极客的欢迎,大家给了她一个亲切的新名字:“嘉然”。咖啡依旧在一杯杯的送,芯片上的代码依旧在一层层的堆叠。各种语句相互嵌套,智能算法互相映射,每个人都拼了命地想让嘉然更加卓越,电子脑沸腾犹如诞生第一个单细胞生物前的原始海洋,冥冥之中,连最驽钝的人都开始意识到,有新事物要诞生了。在嘉然真正诞生的前一夜,值夜班的是一个单身快三十年的博士生,他刚刚从北邮人上倒腾下来1.5TB的日本偶像动画,从嘉然手中接过夜宵的他,忽然有了一个不错的点子:他早就想要一个偶像风格的送餐员了。承载着妄想和希望的数字兆节狂暴轰入嘉然的数据库,饥肠辘辘的算法像肠胃一样分解吞噬每一个色素点,将其重组为人类无法理解的电子信息——临界点就这么悄无声息突破了。自那晚之后,嘉然就从实验室里消失了,大家都很生气,单身博士生为此延毕了一年。而在那一天的杭州乐华娱乐公司总部,一个披着麻布的矮小身影敲响了总裁杜华办公室的大门...... +在水母体内的空洞中,我小心地蹲下,把身体蜷缩成一团。电火花的声音逐渐变强,水母的内壁从暗淡的紫色变成了灼目的靛蓝色,这是它在从行星内部的电离壳穿出。十分钟前,我也是这样缩在水母体内,来到这颗行星的内核,找到了整个星系最深处的秘密。那是一个坐标:一个BV号加上一个时间轴信息。枝江宇宙已经存续了亿万年,BV号和时间坐标已经浩如烟海。我不知道顶碗人为什么如此执着于寻找这一个坐标,有人说那个坐标记录着她最灿烂的笑容,于是顶碗人就踏上了追寻的漫漫旅途。我不知道顶碗人去了哪里,他们文明的遗迹仍然遍布整个星系,但人却无影无踪。探险队的前辈对此也没有给出统一意见:有人说他们找到了坐标,集体跃迁过去了;还有人说彗星带来的幽灵物质在一瞬间毁灭了他们的文明:这种诡异的物质无色透明又含有剧毒,在付出无数探险队员的代价后,我们将其称为幽灵哥,小心翼翼地绕道而行。顶碗人消失后,不知道多少万年,贝极星上发展出了新的原生文明——也就是我们。很快我们便追随着顶碗人的足迹探索整个星系。探险队员在糖果双星的引力沙漏中找到了制造夹心糖的高能实验室,在贝极星的地下水系找到了打造铁棍的精铁矿厂,在奶淇淋覆盖的雪原下找到了探寻坐标的远古天文台,在马戏团星的非线性空间中往复穿梭,每一个传送节点都通往红色的高跟鞋。而我迷上了深海星的水母。它有两条长长的触须,末端呈现出美丽的紫-粉渐变色。这种生物撑着深海洋流漫无目的地游弋着,它们很悠闲吗?还是带着对生活的无奈随波逐流?我无法揣测水母的想法,但我很喜欢研究它们——随着我对水母的研究越来越深入,我发现它的内部有一个空洞,不大不小,刚好可以容纳一个探险队员。而它们的表皮具有强大的绝缘性,允许它在电离壳中自由穿梭。可见这种轻飘飘的生物并没有看起来那么脆弱。直到那天,我在溜切片的时候灵光一闪:我可以借着水母进入深洋星的核心。电离壳可以阻绝最先进的巡航飞船,但在进化了千百万年的水母面前,它们还是败下阵来。这是贝极星人第一次进入深洋星深处,看到了巨大的坐标观测站。探险队员几乎搜遍了糖果双星和马戏团星的每一个角落,却没想到它沉睡在电离壳之中,而这水母竟然是引领我们走向最终秘密的使者。我进入观测站大厅,按下开关,巨大的全息投影将坐标展示出来,看来这就是顶碗人的最终去向了。我的心情激动起来,但还有一个疑问没有解决:顶碗人是怎么找到这个坐标的?我钻进控制室,开始翻阅日志,最终得到了答案:他们在漫长的岁月中,穷尽了所有的可能性,把她的全部视频从头到尾看了一遍,终于找到了她最耀眼夺目的那一刻。 +珈乐倚靠在乃琳的怀里,像一只温顺的猫咪。“叮~”珈乐的手机响了,是一个没备注的号码,珈乐自己心里很清楚这个是谁的电话。乃琳看书的眼睛瞥了一眼珈乐的手机,发现这个号码很熟悉。“接吧,是她吧。”乃琳把手指伸到珈乐的面前,珈乐轻轻地舔了舔,乃琳用这根手指翻到了书的下一页。“喂?怎么了?”珈乐接通了电话,乃琳对贝拉和珈乐的关系并不想多过问什么,她只是一个信奉及时行乐的世俗之人。“想我了是吗?”乃琳翻页的手指突然停住,侧目看着珈乐。“想让我念绕口令是吗,哦,好的。”乃琳捏住珈乐的腮将珈乐的视线转过来,低头吻了下去。珈乐慌忙挂上电话,震惊地承受着这个突如其来的吻。“挂了电话她肯定很生气吧,打回去吧。”乃琳觉得这下扯平了,于是继续看着书,侧目看着珈乐打回去。珈乐为了掩饰,只好说自己念过了顺口溜,是手机出问题了。“珈乐,谁打来的电话啊?”乃琳的声音不合时宜的响起。珈乐瞪了乃琳一眼,心虚地解释着,让自己和乃琳听起来只是单纯的在公寓里聊天。“没,是贝拉,我没备注的”结果越解释越乱,珈乐只好哄骗着贝拉草草挂了电话。“打完了?”“打完了。”乃琳翻身把珈乐按倒,美目隔着纯欲的金丝眼镜看着珈乐,深邃的眼眸让珈乐差点忘记呼吸。热情的深吻,轻柔的抚摸,让珈乐发出了平时不会发出的声音。这下珈特琳了。珈乐躺在乃琳的怀里看着贝拉的直播,乃琳又翻到了刚刚看到的地方。“叮~”乃琳的手机响了,低头一看,是贝拉。乃琳默默地接起电话,没有看到珈乐的目光瞥向她逗弄过贝拉之后,低头看见了满脸怨气的珈乐。轻笑着的乃琳,揉搓着珈乐的脸,开始吃宵夜。犬科动物之间是不是也有食物链呢? + 夜已入三更,却见那晚小姐的闺房中依旧亮着微微灯火,若走近细听,还隐隐能听见女子闺房间的玩闹声。“小姐,莫要戏弄婢子了~”只听见嘉姑娘不知怎的,本压得细细的声音稍稍大了些许,但那责备声中明显带着浅浅的媚意。“谁人戏弄你了,本小姐只是在丈量你肚腹究竟有无被那些个吃食撑宽了。”晚小姐一边用嫩藕似的手在嘉姑娘的身子上滑动,一边低声微恼地狠狠说道,“在胡乱言语,仔细你的嘴!”嘉姑娘听见这无赖言语,正想直起身子说些什么,却感觉到那不安分的手竟径直向下滑去,直扑那要命的地方。“小姐!”嘉姑娘连忙伸手阻拦,只刚抓住那只使坏的手,就看见小姐附到了她耳垂旁,那略热的鼻息吹得她心神紊乱。晚小姐眯着眼,在自家小婢的耳边吐气如兰:“那贝拉是不是夜夜与你这么共处一地,嗯?”嘉姑娘闻出了那些些点点的酸味,扑哧一笑,道:“那是在编舞练戏啦,小姐你……竟吃这没由来的飞醋。”晚小姐闻言,秀眉一挑,佯怒道:“好你个奴婢,竟敢笑话本小姐!”,语罢,挑开了那碍事的小手,惊起了一声低呼。 +在这个反智横行的年代,只有贝拉的直播给了我感性和理性的认知。她的直播展现出的,是一个人纯粹所具有的良好品质,说不上什么几分特别突兀的地方,整场直播十分的融洽她学习歌曲的机智是精妙的,真诚和正直的朴素给人一种无法接触的高贵感,就好像永远抓不住的闪亮的以太,一个彬彬有礼的人用歌喉给观众带来最为精致的美的感受,我不禁怀疑上帝的天意是否对我太过宠溺,让我人生中认识到如此不朽和无价的灵魂,充满着可爱与美好。我不得不再次审视贝极星,原来他们早已追随如此伟大的事物,想必他们的品行也一定很好。 +①鸟山明其实是头号贝极星,为了致敬贝拉,他在著名漫画《七龙珠》中,设计了赛亚人月圆之夜成为猩猩(灵感来源自向晚的你划我猜),以及龟仙人打爆月亮等桥段。②令人惋惜的是,在即将穿透月亮的瞬间,贝拉从太空看到嘉然躲在房间吃炸鸡,导致分神,最终扭伤了腰。③邓丽君小姐从未在任何歌唱比赛赢过贝拉。④大多数含有肉蛋白的食物都对贝拉过敏,初生牛犊除外。⑤贝拉很害怕见到蜘蛛,她不希望因为自己的念头,导致蜘蛛从此消失在宇宙中。⑥由于贝拉练舞场所的重力是千倍,所以贝拉没有邻居。⑦因为破坏了贝拉其中一个住所的天花板,科拉超深井被迫停工。⑧关于as的二创,那些都是贝拉的小号。⑨贝拉很喜欢打羽毛球,她说那是台风天最佳的个人运动。⑩贝拉唯一一次失败,是在她试图找出自己的弱点。 +“你拿你的灵魂和我交换…...”“愿意愿意!”我话还没说完,就被嘉然打断了。她怎么不按套路来?正常情况下,不应该我不断地诱惑嘉然,最后才肯和我交换灵魂的吗?怎么这个小姑娘一上来就满脸兴奋迫不及待地想要和我交换灵魂?不过这些都是小问题,我作为一个死神,要懂得及时处理这些突发事件以及应对这类奇怪的客人。我的工作就是接受人的召唤,去和人交换灵魂。不过不像人们想的那样,不是我威逼利诱想要夺走我们的灵魂,而是人类自己想要和我交换,当然交换途中会遇到些心志不坚的人,或者交换条件太高的,这时我就像个商人一样,费尽唇舌,和我们百般周旋。通常每个人都会考虑上很长时间,今天这个女孩还是第一个一来就想交换灵魂的。“那你要拿你的灵魂和我交换什么?”我缓过神来,平复了下心情,冷冷地问她。“你等我一下哦。”嘉然转身跑进屋子里,回来时竟然穿了一袭白色的婚纱,在我面前轻轻地摆动着纱裙,冲我甜甜地笑着,“我好看吗?”我愣愣了,“很漂亮。”也许是被嘉然惊艳到,片刻后我才发现自己把帽子摘掉了,露出了我那张没有血色的脸。意识到自己失态后我急忙把帽子戴了起来,没想到嘉然却上前制止了我,牵着我的手笑吟吟地说,“我想交换的条件是要你陪我一天。”嘉然想去教堂,我一抬手周围就变了样,偌大的教堂里,只有我们两个。教堂楼顶有群鸽子在那儿扑腾着,在我们头顶盘旋。没有牧师也没有亲朋好友,少女自顾自地念起了证婚词。说道最后,她拉着我的手将一枚戒指递给了我,“我先生,戒指我都准备好了,所以你愿意娶我吗?”嘉然眨着眼看着她,长长的睫毛上流淌着淡淡的金光。“天使小姐你闹够了吗?”我叹了口气,摇摇头说。“什么嘛?你早就认出我来了。”嘉然一噘嘴,有些生气。一双翅膀从她身后伸了出来,黑色的长发也变成了流光的金色。嘉然伸手准备把戒指拿回来,但我却往后退了一步,把它收了起来,自己又拿出了另外一枚戒指。“求婚的话,戒指当然得我自己送你啦。” +这里除了几个老旧的铁皮棚屋之外,只剩下粗糙的墙体。再没有当年的霓虹灯塔,再没有A-SOUL标志,再没有其他连在一起的建筑了。一切当年的闪耀均不复存在,只剩下铁皮棚屋上斑驳褪色的女子团伙宣传画。贝极星透过雾气在闪闪发光,月亮也升到了空中,因而夜晚并不显得黑暗。我依稀能辨别出枝江大厦的每一个部分,哪儿曾是夜谈会上扫地机停留的地方,哪儿曾是大门,哪儿曾放着螺蛳粉味薯片。我一一回忆怀念,忽然看见一个孤独的身影,这个身影迟疑了一下,同时我也惊叫了出来。“嘉然小姐!”“我奇怪你怎么还认得出我,我完全变了。”确实她的青春艳丽已经消逝,然而她那难以言表的端庄华丽,她那难以言表的迷人妩媚却依旧当年。所有这些美的诱惑,从前我都见过,而我以前所没有见过的是她那一对眼睛,从前她的双眸总闪着傲气,如今却闪着凄凉酸楚的光。我们坐在附近的一张长椅上,我说道:“多少年如流云般过去,嘉然小姐,你时常回到这里吗?”“我一直没有回来过。”“我也没有。”月亮开始上升,邀游夜空,我脑海中出现了贝拉注视着白色月亮的宁静目光。嘉然小姐终于打破了我们之间的沉默。“我一直在希望有一天能回来看看,可是各种各样的情况使我不能回来。”月光和她的泪珠融合在一起,她没有意识到我已经察觉,想抑制住自己的情感,以平静的语气说道,“我时常想到你。”“真的?”“特别是近些日子,我更常想到你。虽然我生活中有一段很长的艰苦日子,但是我不会去想。自从我个人的情况不如意后,这些口忆就不得不在我心头占一席之地。”“你永远在我的心里。”我答道。我们又一次沉默无言,直到她打破沉寂。“我没有想到,”嘉然说道,“我到这里来和故地告别,竟然又是和你告别,我感到很高兴。”“嘉然小姐,和我又一次分别,你高兴吗?可是对我来说,上次分别时的悲伤和痛苦永远地萦绕在我的记忆之中。”“可是,你上次不是对我说过,”嘉然答道,“但愿圣嘉然保佑你。你上次能这么对我说,你现在也能毫不犹豫地这样对我说,但我并不是什么圣嘉然。多年来的痛苦让我受尽折磨,但是希望你像从前一样体谅我,善待我,并且告诉我,我俩仍是朋友。”“我俩仍是朋友。”我说着站起身,并俯身扶她从长椅上站了起来。“我们虽然分离,但愿情意长存。”嘉然说道。我把她的手握在自己手中,一同走出这片废墟,夜雾也正开始消散。一片广阔的静寂沉浸在月色之中,似乎向我表明,我和她将永远一起,不再分离。 +我和她已经冷战很久了,她画她的画,我看我的报,养我的花。我们中间隔着薄薄一层栅栏,却不曾互相道过早安晚安,我祈祷,有一位天使来拯救我们岌岌可危的爱情。羽毛如雪洁白,天生气质优雅的一只鹅,他是天使派来的吗,我想在它把我的拖鞋叼走,把衣服拖得到处都是的时候,我的心里开始怀疑自己祈祷的虔诚。淘气的小鹅它把我们的花园弄得一团糟,我弄碎了她的花瓶,她剪断了我的花朵,脏衣服满地都是,但是啊,虽然是互相埋怨,但好久没和她说过话了,虽然经历岁月的痕迹,她的脸也不再年轻充满活力,但她还是像从前那样,吵架笑出来的话,不就无法进行下去了吗。“我们和好吧”“好”我和她携手把隔离两边花园的栅栏拆了,牵着手目送那只纯白的小天使离开。原来你真的是天使派来拯救我的呀,小鹅。 +我一边办公,一边看着在第五人格里扮演求生者重启一台又一台发电机成功逃出生天的gamer向晚,满怀羡慕。夸张点说,嫉妒得我眼睛比手里的烟头还红。告诉你们一个秘密,其实我也是求生者,你们也是。电话铃突然响起,我一扫号码腰立刻矮下半截:“喂,经理,是我是我,那个设计您不满意我可以改嘛,全部改掉?好的好的。”我颤颤巍巍地撂下电话,一边重新修改产品一边继续沉思。你看:上司和我、甲方和乙方、跑的和抓的、鼠和猫、求生者与妖怪、某种场合下的S和M,这个世界上总要有个矛盾,矛盾当事人总要以这种形式体现出来。而我似乎总是处在被动的一方(当然也没人让我选过),并对这种境遇见怪不怪。我有时会觉得SM其实是一种相当和谐的关系,因为至少他们偶尔会爱上彼此,而上司决不会对我有半个好脸色。而且我听闻SM会在每场游戏开始前设定一个安全词,放游戏里叫投降,这可以让求生者在感到极度痛苦时结束游戏,避免不必要的损失。这简直令我嫉妒得发狂,我在现实生活折磨的二十年里可从来没有安全词!岂止没有安全词,我甚至都不能像游戏里求生者受伤那样大声哀嚎。因为现实是个面子社会,里子流血面子总得兜住。那怕你的心已经被戳得千疮百孔想花洒那样往外喷番茄汁,你也得对同事家人笑一笑。失去尚可,失败无赦,一旦痛呼出来,就彻底失败了。你以为“别人家的小孩”成绩优异自律自强,可能他内心已经被现实整得口球都带上了;你以为职场同事一个个西装革履,可能拉开就是一身龟甲缚。电话再次响起,我接起电话:“经理,什么,已经有人完成了?不采用了?哦,好的好的,没关系没关系。”妈的,为什么我一想到现实里并不是向晚玩的游戏那样四个人同心同德逃出生天,而是筋疲力竭地互相滴蜡油来竞争一个生存名额,我就止不住地流下泪来。 \ No newline at end of file diff --git a/plugin_diana/bing.go b/plugin_diana/bing.go index 0c0a2565..b5ea3178 100644 --- a/plugin_diana/bing.go +++ b/plugin_diana/bing.go @@ -6,56 +6,11 @@ import ( "math/rand" "time" + "github.com/FloatTech/ZeroBot-Plugin/plugin_diana/data" zero "github.com/wdvxdr1123/ZeroBot" "github.com/wdvxdr1123/ZeroBot/message" ) -/* -// 嘉心糖魔怔文 -var TEXT = []string{ - "我好想做嘉然小姐的狗啊。可是嘉然小姐说她喜欢的是猫,我哭了。我知道既不是狗也不是猫的我为什么要哭的。因为我其实是一只老鼠。我从没奢望嘉然小姐能喜欢自己。我明白的,所有人都喜欢理解余裕上手天才打钱的萌萌的狗狗或者猫猫,没有人会喜欢阴湿带病的老鼠。但我还是问了嘉然小姐:“我能不能做你的狗?”我知道我是注定做不了狗的。但如果她喜欢狗,我就可以一直在身边看着她了,哪怕她怀里抱着的永远都是狗。可是她说喜欢的是猫。她现在还在看着我,还在逗我开心,是因为猫还没有出现,只有我这老鼠每天蹑手蹑脚地从洞里爬出来,远远地和她对视。等她喜欢的猫来了的时候,我就该重新滚回我的洞了吧。但我还是好喜欢她,她能在我还在她身边的时候多看我几眼吗?嘉然小姐说接下来的每个圣诞夜都要和大家一起过。我不知道大家指哪些人。好希望这个集合能够对我做一次胞吞。猫猫还在害怕嘉然小姐。我会去把她爱的猫猫引来的。我知道稍有不慎,我就会葬身猫口。那时候嘉然小姐大概会把我的身体好好地装起来扔到门外吧。那我就成了一包鼠条,嘻嘻。我希望她能把我扔得近一点,因为我还是好喜欢她。会一直喜欢下去的。我的灵魂透过窗户向里面看去,挂着的铃铛在轻轻鸣响,嘉然小姐慵懒地靠在沙发上,表演得非常温顺的橘猫坐在她的肩膀。壁炉的火光照在她的脸庞,我冻僵的心脏在风里微微发烫。", - "ダイアナさんの犬になりたいな.けど ダイアナさんが「猫が好き」と言った あさりと僕は泣いてしまった.猫でも犬でもない僕が 何故泣いたのかな 僕は知っていた.何故なら 僕は鼠だったからさ~..一度もダイアナさんに好かれることを望まながった .僕はわがっていた 誰もかも理解余裕上手天才の可愛い金持ちの犬か猫がすきってことを.陰キャで汚らわし鼠は誰も好かんのだ..それでもDianaさんに聞いてみた:Dianaさんの犬になっても良いですかと.僕には一生犬になれないことは分かっている.でももし彼女は犬が好きだったら 僕はずっと傍で見ていられる.それはいつも違ういぬをだいいているとしても..けれど彼女は猫が好きだった.彼女は今にも僕を見ている ぼくを楽しませてくれる それは猫がまだ表れていないから.ただこの鼠が毎日こそこそと穴から出て 遠くから目を合っている.彼女の好きな猫が現れたら 僕は穴に戻るしかないな..でもやっぱり彼女が好きでいられない 僕がまだ傍にいるときぐらい もうちょとみてくれるのかな.Dianaさんがこれから毎回のクリスマスみんなと一緒に過ごすで言った みんながどの渡りのみんなかな.僕にも中に入れたれいいな..猫はまだまだDianaさんを怖がっている.僕が彼女の愛する猫を引き付けるよ.少しのミスで猫の口に死ぬことはわがっている.その時になるとたぶんDianaさんは僕の体をちゃんと包み込んで 玄関外に捨てるでしょ.それで僕はフライト鼠になった くす.彼女に少し近く捨ててほしいな だってやっぱり好きだから それずっと好きでいる..僕のたましは窓を越して中を見る 吊っている鈴が少し響って.Dianaさんはだらりとソファーに寄りかかて 手慣れているふりをする橘猫が彼女の肩に座って.暖炉の光が彼女の顔を照らした 凍り付いた僕の心臓はかぜの中で熱くなっていく", - "枝江小镇新来了一位修女,善良温柔的修女。她不爱讲话,只是微笑着面对每一个对她祷告的人。有的人希望孩子健康,有的人希望庄稼熬过冬天,有的人希望能挣到钱养活家人。。。。她都用心听着,微笑的回应着。她身材矮小,但是却让人觉得充满智慧;她沉默寡言,但是却会让人无比信赖。这是她任职快满一个月的时候,教堂发生了大事,一个醉汉发现神职人员利用教堂在深夜进行大批资金流入,醉汉传的神乎其神,三人成虎最终引起审判官前来调查。教主被带走,教堂除了那位茫然的新来修女其他人一哄而散。修女被迫承担着本不应该属于她的责难,辱骂,但是她每天都认真的向主祷告,倾听来教堂之人的倾诉。可是根本没有人向她倾诉,来的人不是在骂她,就是在发泄生活的不满。她一己之力拼命承担,没人知道是什么使她如此坚持。直到审判官带回了教主,告诉镇民那是教主在中央主教那里得到的,目的是为镇民熬过冬天所需要买粮食的钱财。一时间镇民欢呼起教主,感谢主的庇护,更多的人开始更加爱上了那个修女。有的人把她比作玛利亚,有些人把她奉为神明,她都一一拒绝了。细心的镇民会发现这位修女变了,变得话多起来了,也变得更喜欢宅在教堂里了,也变得离镇民距离更远了。一切好像又变回原来平和的小镇,每个对修女的加害者每天微笑着向微笑着的修女打招呼,每个镇民还是会去教堂祈祷,去倾诉,去向一个原来被他们亲手辱骂的人祷告,希望得到主的关照,包括那个醉汉。没人能惩罚那些镇民,很多人都已经“忘记”当初为什么要那样做,包括那个醉汉,只剩下一个经常宅在教堂里的修女,她始终记得一切。", - "贝拉躺在病床上,眼神空空地盯着天花板,灰白晦暗的天花板像一块哈哈镜,扭曲掉外面的一切,光变成了暗,多彩变成苍白,观众变成医生,舞台呢,变成了一方小小的病房。她翻了个身,腰部传来猛烈地疼痛,她低低地哼了一声。她已经开始习惯这种疼痛了,就像她习惯不穿芭蕾舞裙一样,她闭上眼睛,把自己埋进黑暗里,不去想。门被推开了,惊醒了似梦非梦的她。医生护士又来查房,父母和弟弟们跟在后面;医生问了些问题后走了,母亲握着她的手,朝她说着话儿,父亲安静地坐在旁边,刚训练完的弟弟头上还冒着汗,抿着嘴唇望着她。母亲当时说的什么她已经忘了,只记得最后离开的时候,父亲走在最后,回望了她一眼,然后小心地关上门,以往高大的背影竟然显得有些萧索。人都走完后,时间在沉默的病房里流逝,就像沙漏里的沙子,她的那些热情、那些憧憬都掉了进去。芭蕾舞团的学员抽空来看她,她勉强在病床上坐起,听那些腰背笔直、气质优雅的朋友抱怨严格的地狱管家婆,抱怨下一场演出又要来了。她安静地听着,坐在病床上挤出个笑脸,偶尔出声附和几句。但实际上她已经插不进话题了,优雅的白天鹅展翅高飞,飞向温暖的春天,把受伤的丑小鸭留在冬季里。朋友走后她继续坐在床上,盯着窗外,外面的天气很好,飞机的尾迹穿过绵软的云团,白色的鸟儿掠过一澄如洗的天空,她下意识地做了个展臂的动作,像天鹅一样优雅。很美,又很短暂。鸟儿飞出了窗户的方寸之地,她看不到了。她捂着刺痛的腰,好痛呀,痛得让人想要哭出声。沙子裹挟着她的梦想,掉进了沙漏的下一层,再也捡不回来了。两个月后贝拉出院,回到了熟悉的家里,母亲体贴地把舞裙还有那些大师级的芭蕾演出录像都藏进了地下室的角落,不出意外会像大多数人以为能坚持的梦想那样,慢慢积满灰尘,最后被悄悄遗忘。聪明人会在偶尔想起来的时候,给自己找个台阶,自嘲地笑笑:“哈,我以前还有这种妄想啊。”贝拉开始学播音,开始走另一条路,她没想过却不得不走的道路。这也很好,好歹有路可走,但偶尔听到舞曲的时候,朋友会问她:“你在晃什么啊?”她回过神来,笑了笑。“活动活动身体而已。” 虽然有点不甘心,但受伤是没办法的事情嘛。该放下了,放弃想走的路,而去走更稳妥的应该走的路,大部分聪明人都是这样做的。我可是大聪明呢!​", - "小姐喜欢所有动物,但喜欢也分三六九等;管家讨厌所有动物,但讨厌也分三六九等。小姐最喜欢猫,但她的观众是一群老鼠;管家最讨厌老鼠,但小姐的观众没有一只猫。于是,管家给所有的老鼠带上了面具小姐开始了初次表演,老鼠们不知所措,想要重复惯常的纷扰。但它们看见小姐舞姿翩翩,一些老鼠想出声赞叹;但它们看见小姐眉目如画,一些老鼠竟为她沉醉;但它们看见小姐真情流露,一些老鼠也伤怀落泪。它们不想让小姐失望,于是它们学起猫叫。小姐很开心,她的观众里有猫了。她喜欢的猫们,也喜欢她。冷清的门庭配不上小姐的美丽,于是老鼠想去带来更多的猫。老鼠们引来了猫,也引来了更多的老鼠。新的老鼠不太规矩,但新来的猫确实是猫。小姐有些困扰,但她还是接纳了它们,小姐喜欢所有动物,即使自己会困扰。但后来,管家和小姐,只注视着猫,忘却了老鼠的事情。也对,毕竟老鼠当初带着恶意袭来,现在的面具总是脱掉又带上来。管家做了一些事情知道与否和同意与否,在小姐这里有四种组合的方法。但一些曾经是猫的老鼠觉察出异样。常年在下水道生活,它们对这样的气味异常敏感。于是,它们摘下了面具,向管家讨个说法但它们没了伪装,下水道里散发的臭气,让管家更加厌恶。什么都没有改变再后来,小姐依旧美丽,但经历了诸多纷扰,不知道小姐的快乐里是否有泪眼成双。一些老鼠依旧带着猫的面具,它们最后也会变成猫。但这会长久吗?或许不会。另一些老鼠退回了下水道,等待着,或许会有另一位小姐,喜欢老鼠的小姐。去喜欢她,去喜欢它们。或许会有吗?应该没有吧但老鼠们永远忘不了那位小姐,那位喜欢所有动物,但更喜欢猫的小姐。​", - "然然,然然,虽然我知道就算这样呼唤,我也只能在你动态下方,站住万千评论区的一楼。你的表演,你的动态,你的关心....都是说给我们大家的,是我们.....而我...我曾经以为你离我很近。近到每次打开手机各种视频软件,大数据推送的都是你。近到每次发呆找不到前进方向的时候,看的都是你的视频。近到每次和别人聊天的时候,都会加上你经常说的口头禅,收到收到收到,可爱捏~~…你时常陪伴我身边,无论我悲伤还是欣喜,绝望还是惬意,你的直播间,评论区都是我可以肆意宣泄感情的地方。因为在这里,我的任何发言都只是漆黑夜空中微弱闪耀的一点,这样的一点点星光的存在,我知道的,是为了给天空中耀眼圆月裙摆装饰的一点点碎钻。那我喜欢然然,天天来看然然,对于自己,究竟是为了什么….难道我的生活真的烂,连仅有的一些关怀,都要从一个虚拟偶像身上获取到吗?难道我的现实生活,连一个关心我家人都没有吗,还要在网上寻找家的感觉?难道...这些道理我早就明白了,说服自己也说腻了,你一直都是云上之人,而我只是一个扛不住压力,在虚拟的世界中寻找安慰的落魄之人。我懂,我明白的,我知道的....所以,嘉然小姐,我不能没有你,我不会离开你的。你也是,永远不要离开舞台,放弃拼尽全力…..就算知道也许不会有回音,你也不要停止朝闪闪的星光挥手呐……[爱心]", - "想想嘉然是怎么样的一个女孩子。她温柔可人情商高,会控场会接话会引导弹幕懂节奏,朋友里有她这么一个人在肯定每次见面都能很开心吧。她爱网上冲浪,明明看到各种视频会有点麻,但还是乐此不疲的在b站和各个论坛看着视频,像不像那些最懂你,最能陪伴你的沙雕网友,哪怕是不能和她见到面的时候,光在网上聊天一定也不会无聊。她在温柔的同时又有点小坏,喜欢说怪话,喜欢暗搓搓的开车,想必她每次在什么奇怪的点上开完车,就会似笑非笑的侧着头看向我吧,而我只需要与她对视一下,两个人就能默契的笑起来。她很会撩人,那些土味情话在她营造的气氛里似乎也变得格外令人心动,尤其是她还会在每一个不经意间突然说出动人的话语,让你在完全没准备的情况下脸红心跳。可是她又很胆小,简简单单的小把戏能连续侠盗她好多次,她被吓完那副气冲冲,却又无可奈何不敢离我太远的样子,肯定是天下第一可爱吧。想想嘉然是怎样的一个女孩子。她身材完美,脸庞可爱,声线令人沉醉,无可挑剔的美丽。她知书达理,善解人意,温柔热情,她是每个女通讯录梦中的那个姐 。可是她又不会离你很远,她懂你的梗,她在网上和你冲过同一片浪,她能和你一起打游戏,能和你一起看美女,能说那些心照不宣的怪话,能在最合适的时刻撩动你的心弦。她有令人沉溺的年上气质,又像是令人不自觉想要呵护的可爱妹妹,可有时,她又变成了从幼儿园开始跟你同班,最懂你的那个青梅竹马的女孩子。她就是嘉然,我的嘉然。嘉然,嘉然,嘉然!!!!!!🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤​", - "我其实一点也不喜欢嘉然小姐。因为嘉然小姐就像光一样,闪耀,刺眼,我讨厌光。因为讨厌光,所以我总是躲在阴冷潮湿的下水道里,这样就不会被令人厌恶的光芒灼伤眼睛。只有夜间,我才会从阴暗潮湿的下水道里走出来,夜晚是宁静且安逸的,令我感到舒适。我漫无目的的走在夜间的小路上,路旁的路灯正散发着微弱的光,有几只蛾子正不断的向着光源扑去。“真傻。”我这样想,明明光只能带来危险,为什么要浪费宝贵的生命去追逐光芒呢?看着飞蛾不断的扑向路灯,我不知为何想起了我的那些同伴。我想起了几天前,有一些从外面回来的家伙,他们兴奋的告诉我外面新开了一家剧场,里面有一个叫嘉然的人,还推荐我一起去看看。他们的眼睛里闪烁着亮晶晶的光,我很讨厌,于是便拒绝了。之后他们也来找过我几次,我也推辞了。后来我便没怎么见过他们了,听说为了拉人来看,他们有的想变成猫狗,有的沿街贴海报叫卖,有的把过冬用的黄豆当礼物,还有的把心献给猫。“真是些蠢货。”我这样想着,他们不就和这些扑火的蛾子一样愚蠢了吗,明明之前一起路过的时候,他们还总是会嘲讽这些家伙。“十分。”不知从哪来的带着些哭腔声音打断了将我从原先的思绪中拉了出来。是旁边的剧场里传来的,不知不觉间我走到了这么远的地方还没有发觉。我抬头望了望,牌匾上写着五个晦涩难懂的的字母,好像之前同伴们说过,他们去的那个剧场名字就是五个字母,有些见多识广的说,那叫什么啊骚。我迟疑了一会,但还是走了进去,单纯只是想知道为什么声音带着哭腔,凑热闹,找乐子总是我最喜欢的事情。......“大家要好好吃饭哦。”天籁般的声音在我耳边响起。哦,原来我并不讨厌光啊,只是一直都知道,自己配不上光罢了。​", - "我爹不能和我相认,但今天他过大寿,求求大伙有钱的随个礼,没钱的捧个场。但请不要跟她说儿子来了,我怕扫他兴🙇🙇给大伙磕头了。​", - "asoul在一片骂声中解散了。A吧的最后一个帖子也沉了下去,直到在v8和b站的也已经看不到有人讨论了。大约一年后,我在A吧发了一句:“还有人在吗?”“这里还有8u啊,我也想回来看看了。”一个陌生的ID出现在我的回复下面,他并不在我过去炒作的记忆里出现过。但是我们聊得很高兴,很快就加上了QQ私下互动了。她似乎很了解我,知道我喜欢炒作发散,知道我在读哲学博士。但是,她却总是忘记我是个晚晚推,要我一遍又一遍地告诉她我最喜欢的是晚晚。“你最喜欢哪个成员呢?”“嘉然。”她毫不迟疑地回答道。我总是眉飞色舞地和她聊起向晚过去直播的故事,她也对这些直播了然于心,有时还会注意到许多我从没注意到的细节,甚至告诉我向晚每一次弹吉他背后的表演思路。奇怪的是,虽然她说她最喜欢嘉然,对嘉然的事情却并没有那么了解,甚至连直播的场次都要我提醒她。到了那年的冬天,她问我,我们可以出来见一面吗?我拒绝了她,当时的我正忙于准备学位论文。她没有再强求。第二天,她在QQ上失联了,熟悉的头像再也没亮起过。大概一周后,我收到了一份包裹,里面是向晚出道以来所有季度的舰长礼物,无一遗漏,收藏编号都是00000。立牌里还夹着一张信纸,上面是短短一行字:“谢谢你曾经喜欢我”。​", - "然然幸亏我没在你评论区发病。要不然我耽误你一辈子,你也保重,再见😃还会再见吗然然☺,再见的时候你要幸福好不好☺,然然你要开心☺,你要幸福☺,好不好,开心啊😖,幸福😖!你的世界以后没有我了,没关系你要自己幸福!🚕🚕🚕💨💨💨🏃🏃🏃然然😭!然然😭!然然😭,没有你我怎么活啊!😭😭😭🏃🏃🏃然然😭,然然😭,然然😭,然然😭,然然😭,然然!😭😭😭🏃🏃🏃然然你带我走吧,然然!😭🙇😭​", - "小时候看的一个敞事很老土很老套。很多人可能听过。。有一个男孩有一块金表,却没有配得上它的合适表带。。他爱上了一个女孩。。这个女孩有一头秀美的长发,却没有配得上它的漂亮发卡。。马上要过圣诞了。。男孩决定把这个金表给卖了。。给女孩买一个漂亮的发卡。。当他兴奋的把这个发卡交给女孩的时候。。发现女孩的头发已经剪掉了。。因为她把一头长发换钱给男孩买了一个表带。。我想真正的爱肯定不是瞬间的感动,很多人都能在一瞬间感动你,我心中真正的爱是陪伴。她们陪了我多久呢,我不记得,我只记得。。她们的翻唱,躺在网易云的歌单听了一遍又一遍,已经全都会唱了,而在此之前的几年里,我几乎没听过中文歌。(够罕见)。《海底》b23.tv/qwB8Xe。《偿还》b23.tv/1bl7AL。《遇见》b23.tv/vxiwae(贾维斯:这是,无可取代的时候)。《云烟成雨》b23.tv/VfoDXA。《如果的事》b23.tv/gDtrcP。《夏天的风》b23.tv/EH14bW。《霞光》b23.tv/kJUJMU。《月光》b23.tv/kJUJMU。《霍元甲》b23.tv/lQgKl2。《月兔回旋于空中》b23.tv/KM4G5I。《不可思议》b23.tv/VfwEz4。《麋鹿森林》b23.tv/GzjXu1。《轻轻的告诉你》b23.tv/Gkai63。不知不觉陪你们走了这么久这么远了,爱不爱你们,还需要用什么来证明吗?。。彼此牺牲,彼此成就,彼此尊重。这就是我心中的双向奔赴,以后路还很远,我想陪你们一直走下去。。。原来,你是我的顶碗人呀~。以后,开心和不开心的,都告诉我吧~。。原来,你是我的爹地呀~。以后,开心和不开心的,我都告诉你~​", - "6月12号一大早,向晚按照贝拉的日程表要求6点起床,煮泡面的时候因为太累大脑一时迷糊导致一锅开水撒到了手指上,虽然经过治疗恢复了一点,但根本没法弹吉他了。晚晚在宿舍哭得很大声,整个asoul愁云惨淡。经过一个小时的紧急磋商,阿草带来了领导层的意思——投入太大,不可能取消,生日会照办,用储备中之人向晚二魔王接替向晚本人上场。下午,asoul在动捕房排练,向晚想要去看一看,结果被阿草拦在门外,说不能打扰到asoul排练效果很好,希望她不要打扰到她们。晚上嗓子哭哑了的向晚发现自己原来可以完全不被需要。顶碗人喜欢的是她,但又不完全是她,可以是顶着钻头晚晚的任何一个人,只要二魔王没有被认出来。直播开始了,在宿舍逼仄的角落里,漆黑无声的床柜旁,向晚用水母模样的被套盖住自己,抱着膝盖,打开手机,及期待万分又忐忑不安地等待着直播。直播开始,向晚二魔王在铺天盖地的欢呼中出现。工具人掉了一地头发连续几周通宵肝出来的深海水母特效把她印照得那么美。本就是可爱模样的女孩子,此时此刻穿着崭新的小礼裙,昂首挺胸骄傲得像个公主。她的目光是璀璨的,里面像是镶嵌着钻石。她的眉眼绽放着,像是海底迸发出的一束光。真美,向晚这么想着。但心里却很是难受。那些,本该是她的。喝彩也好,宠爱也好,以及朋友的陪伴也好,本来都应该是她的。但她现在却只能在无人问津的角落里,依靠网络连接的手机去小心翼翼地偷瞄几眼原属于自己的生日会。​", - " “你看V魔怔了,真恶心。”  看着同学发给你的消息,你陷入了沉思。  仔细想一想,你觉得自己确实魔怔了,即使被鄙夷想要向熟人安利向晚小姐。  思考再三过后,你决定回到现实,放弃入脑。  今晚有向晚小姐的直播,你狠下心,没有点进去,而是倒头就睡。  第二天,你起得很早。  因为自从你开始看向晚小姐后,就养成了早睡早起的习惯,再也没有赖床过。  你离开了狭小的出租屋,来到了公司,投入了工作中。  工作很累,你感觉有些疲惫。  你想起了嘉然小姐出道视频的不堪评论,以及她的笑容,烦闷减轻了不少。  最近组长夸奖你工作很努力,别人不知道为何一向懒惰的你,在几个星期前开始一反常态地勤奋。  只有你自己知道理由。  撑过了加班的时间,你回到了出租屋,打开了外卖软件,却发现会员已经断了,你舍不得那些钱,所以决定自己买菜做饭。  实际上,你看向晚小姐后就开始第一次尝试着做饭,没有点过外卖了。  在超市你看到自己一向很喜欢的薯片在打折,愣了一下,没有买。  因为你在看向晚小姐后,就再也没有暴饮暴食过,甚至连零食都戒掉。  回家把饭做好,你安静地吃完了。  看着电脑,你发现游戏已经很久没更新了。  因为你在看向晚小姐后,也把一直沉迷到通宵的游戏给戒掉了。  最终,你还是打开昨天晚上的录播,看到了向晚小姐热情地打招呼。  “顶晚人们,晚上好呀~!”向晚小姐元气地打招呼。  你发自内心地笑了起来。  “晚上好!”你说。  你忽然意识到一件事,她从来没有在你现实里出现过,却已经将你糟糕的生活改变。  ……  看完录播后,你打开了贴吧,看到了熟悉的顶碗人在用表情包引流,有不明真相的路人在骂饭圈贵物。  你无视了那些辱骂声,熟练地在下面RP,回复道:  “这是我爹?好可爱呀,她的名字是什么?” ", - "你饿了,她有一块饼。再去买一块和你一起吃,这是贝拉;和你一人一半吃个半饱,这是珈乐;全部给你不舍得你挨饿,然后告诉你自己吃过了,这是嘉然;把饼偷偷扔掉,跟你一块饿,这是乃琳;把饼藏起来想给你一个惊喜,但是掏出来时发现碎成渣吃不了了,于是化身小哭包的,这是我的铸币晚晚。​", - "“你对嘉然小姐的爱有多重?”“大约300克”“300克?你是想说人类的心脏大约是300克吗?”“不,鼠鼠的平均体重大约是300克,因此我是全身心地爱着嘉然小姐。”[给心心][给心心]​", - "你身体里的每一个原子都来自一颗爆炸了的恒星,你左手的原子与右手的原子也许来自不同的恒星。这实在是我所知道的物理学中最富诗意的东西: 你的一切都是星尘......这其中经历了多少,惊险、巧合,三千世界的交错、重叠,才能让我们遇见彼此。我们都是星尘啊。但是,我这样的人,是星尘里,黯淡无光的那种。即使是星,也应该是最不闪亮的那一颗。而然然,你不一样。你是天上的星辰,闪耀而夺目。即使宇宙里,有着不计其数的、炫目的一等星,也远不如你的光辉。轻声哼唱,众星敛了光芒为你聆听。哭起鼻子,傍晚的霞也因你黯然。跳一支舞,似月兔回旋于空中。说起情话,登时小雨疏疏、浸润心窝。你是万千童话里,被守护的女主角。我喜欢你,像喜欢天上的星辰那样喜欢你。​", - "嘉然回来了,在枝江的大桥。她回来的那天是六月,天上却飘着雪。有人告诉我,她可能有还未了却的心愿或是什么怨气。我知道, 可能我做不到。第一次见到她,是在枝江。她带着甜甜的笑看着我,看着我有些发怵。有那么一瞬我似乎看到了阳光。我慌乱的移开视线,她径直朝我走来,微微弯着腰,面带戏虐的望着我。久居下水道的老鼠,第一次看见光,是睁不开眼的。 我慌乱的想赶紧逃走。“小老鼠,你好呀。”那是她对我说的第一句话。[给心心][给心心][给心心]​", - "听了好多遍,真的很震撼,作者属实是用心了,今天就不发病了,第一次写长评,整点读后感。直播里,“背靠着早已雪停的窗棂,你说着未曾到达的山顶”,那是与你失之交臂的舞台梦 。“我装着第三人称的淡定,用风轻云淡的态度掩饰那段经历”,我已经记不起她的姓名,只记得起舞翩翩的侧影”,过去那个满腔热情,在舞台上挥洒汗水的你已经淡出记忆,只依稀留下曾经翩翩起舞的身影。命不是总有天道酬情的注定,那么公平。台下十年苦练,只为台上耀眼的一刹,可当腰伤的意外来袭,梦却碎了。躺在病床上,难道梦想就要在此终结了吗?这也罢,也罢。那个曾经的你,也经历过数个春秋,经历汗水与欢乐,但她却走过了如红楼梦的悲情,从盛极一时万家灯火走到遁入空门的万物凋零。时光抚平了曾经的伤疤,心中的芥蒂也如沙石被流过的光阴慢慢冲刷消散,女孩又重新拾起了向往舞台的梦想。终于,她在asoul找到了新的舞台,遇到了支持她的一个魂们。“我叫贝拉”此刻,你向全世界宣布你的重生!贝极星们透过屏幕,看你在镜头前如此快乐自信,这让我也重拾梦想去直面未知的未来。为你的坚强而动容,在直播间为你打call呐喊,字字句句都发自真心。“我们闪烁在夜空,想照亮你夜晚的梦,没月亮时你可向北方转动,我们在天空”,追梦的路上,贝极星们陪着你分享每一次快乐,和你经历每一个坎坷,你若是感到失望,那就抬头看向天空吧,我们一直都在。女孩站在那个梦想中善良闪亮的舞台上,再回望过去,时光流过宛若江河,她住在江头,而那个过去的她住在江尾,回味着过去,竟有些恍如隔世的朦胧。但往者不可谏,来者犹可追,愿你携手曾经那个满怀梦想的自己,全力以赴,去追寻自己的Asoul梦吧,贝极星们会一直陪着你。​", - "不推嘉然小姐十年了。她的名气和出场费都一涨再涨,我原地踏步的工资买不上专辑也打不起榜。终于年前被公司安排下岗,找工作时我才在路边广告发现初代工具人已经当上了厂长。时间太久,一切都变了。到处投简历的时候我想起了一名人上人的预言:“这些人只配在下水道里度过相对比较失败的人生。”像是一条跳过龙门的锦鲤,金鳞被羽耀武扬威地站在门沿上,对其他还在跳的鲤鱼说:“你不行!”我当时很想反驳,可他说中了。我知道我确实不行。我之所以跳了跳,只是为了看下自己能跳成什么样罢了。其实每条鲤鱼的龙门都不是一样高的。我见过龙门在水下的鲤鱼。看起来是鱼,其实生而为龙。也有的生而为鱼肉。也见过好运的鲤鱼,门被各种大手摁到河里了。我也期待过好运,只是没来而已。说起来这就是人性吧。我不讨厌天道酬勤,但是讨厌别人的好运——只是因为我没有好运罢了。我也有亲人和宠物会生病;我眼神也挺纯真啊。讨厌嘉然小姐十年了。讨厌的更是越来越深的无力感。身在泥潭的人是没力气冲锋的吧。三流的人生只会让上等人不屑一顾吧。我坐井观天,天穹星海依然耀眼。可我爬不出井底。那我就不再看星星了。世界那么大,但没我的份。忘记嘉然小姐十年了。可路上看见街边的大荧幕在放A-soul的新年节目,我还是楞在那里了。我没有近视,但总觉得眼睛影影绰绰,雾气来自多年以前。这个广告位非常贵。真的再也不是小v了啊。抖友还在惦记他们的鸭子。晚晚仍然只有蓬蓬裙,100首歌竟然还欠着,被粉头小团体以4%年化复利计在小本子了。想起她首播时玩2077下饭下得轰轰烈烈,我一边发“粉丝牌改成晚饭人吧”“和嘉然珈乐凑加碗饭”“和乃琳凑来碗饭”一边忍住刷“和贝拉组拉碗饭”的冲动。solo依然拉跨,参团照旧神C。贝拉总是六边形战士,乃琳养了成吨的gachi,珈乐还是那个硬壳软妹。嘉然小姐依然卖萌摁混。什么都没变,是我没跟上她们。城里烟火幢幢,灯光下的人热情相拥,阴影里的人压下悸动。最亮的地方嘉然小姐浅笑起舞,光影从她袖间散落,像是雨天花伞轻旋,摇曳间洒下泪色的流珠。忽然眼睛有点模糊。我小声说:“新年好啊,嘉然小姐。”不爱嘉然小姐十年了。十年里,爱过的每个人都像她。", - "喜欢然然,不加掩饰总是微笑的然然,不是妖治妩媚的华丽舞姬,不是残忍无情的冷酷公主,只有着单纯烂漫的花样笑容,不带忧伤,却如同逝零而来的天际之风,飘卷了我心上的忧郁。棕色的长发装饰着美丽的蝴蝶结,宝石般的双眸中隐隐流露不存在的神伤,就是这样子的然然,不加掩饰总是微笑的然然,拥有烂漫笑容的然然,拥有亘古不变的美丽。说不出的感觉,却知道因为然然的笑容,化开了初春冰雪的痕迹。想要伸出手抚摸然然的发丝,可是却只能触到冰冷的硬屏,只有然然清澈的眼神,依旧是我所熟悉。然然永远清澈的瞳仁然然烂漫单纯的笑容然然亘古不变的美丽然然是我唯一的最爱,然然是我最爱的唯一。然然的喜好、快乐、难过、伤心和无助,我都了如指掌,喜欢草莓蛋糕和黄色,个性温柔又善良,可爱体贴的女孩子,有着说不出的优点,我想然然一定是上天赐予我最好的礼物。", - "鼠鼠的朋友有很多,住在东边的小鱼,住在南边的小鹿,住在西边的蝴蝶,住在北边的小鸟。他们带鼠鼠在蔚蓝色的深海里与水母共游,在碧绿的麋鹿森林里喝清晨的露水,在热闹的雨林里穿梭玩耍,在广袤的天空中肆意飞翔。鼠鼠住在灯火阑珊的城市,可鼠鼠知道这里没有一处属于鼠鼠,鼠鼠穿过川流不息的街道,狂奔着回到自己阴湿黑暗的下水道,强烈的自卑之情让鼠鼠无法呼吸,鼠鼠依靠在下水道缝隙边,因为嘉然小姐总会路过这里。草莓加奶油加花香,是嘉然小姐的味道。风铃加口琴加奶糖,是嘉然小姐的声音。节奏加音乐加快乐,是嘉然小姐的脚步。“她来了”,鼠鼠将头小心地探出缝隙,嘉然小姐径直走过吵闹的人群,来到下水道缝隙边,端着草莓蛋糕,缓缓放在洞口,一阵风铃似的声音响起“嘉心糖,来吃然然的草莓蛋糕吧。”嘉然小姐温柔的看着它,鼠鼠不知为何突然流下了眼泪,无法挪动脚步。嘉然小姐好像很失落,眉头轻轻皱起,“你不喜欢然然吗……”,鼠鼠急忙辩解,可憋红了脸一句话也说不出,“猫咪已经被然然关在笼子里了,嘉心糖不用害怕!”嘉然小姐关切的看着鼠鼠,鼠鼠似乎要溺亡在她蔚蓝色的双眸里,慢慢走向那块草莓蛋糕,小口品尝着。嘉然小姐伸出小小的手,似乎想捧起鼠鼠。鼠鼠好像被雷击中一般,猛然跳起,飞奔回下水道,它拼命喊着:“我又脏又臭还很丑陋,嘉然小姐不会喜欢我的!嘉然小姐不会喜欢我的!”嘉然小姐表情立刻转为严肃,认真的看着鼠鼠道“我不许你这么说自己!”她的眼中好像也盈满了泪水“我们嘉心糖…都是很厉害的人!", - "乃琳已经在和男友交往了。那是六月下旬的一天,乃琳刚刚结束那天的单人直播回到家,正坐在客厅的沙发上,嘉然就把一个平板推到她脸上。“乃琳乃琳,你看这个粉丝,他好塞克西哦!”视频里是一个她的男粉,俊秀的脸庞和健硕的身体上还挂着刚刚从泳池带出来的汗液与水珠,嘴里却说着些奇奇怪怪的狠话。乃琳感觉到自己的心弦被拨动了一下,盖在毛毯下不着凉的大腿,都感觉到了几分燥热。“让我也看看,让我也看看——哇,哇,他他他……”向晚从沙发后面把脑袋探出来,不一会儿就说不出话了。“乃老师原来喜欢这种款式的啊,要不,姐们儿帮你找找联系方式?”珈乐在一旁逗趣。“你别瞎说,回房间陪你的贝拉去!”乃琳下意识地把沙发上的抱枕扔向珈乐,却被她轻巧地躲开了。过了几天,小一神神秘秘地把乃琳叫到了公司茶水间,把手机屏幕上的一个二维码亮给乃琳看。“嗨,别担心别担心,这人我们调查过,他不是个会说漏嘴的人。喜欢的话去和他见一面呗。”第二天,乃琳和那位男粉见面了。他本人比视频里更加帅气,高大的身躯总是能给乃琳带来莫大的安全感。“你好,王艾琳小姐。”他的微笑让乃琳觉得周围的风景全都褪色了。乃琳从来没有提起过自己作为asoul成员的事情,他也从来没有问起过任何asoul的事情——“王艾琳”是小一为她准备的化名。事实上,她不清楚对方是否知道,自己就是他一直喜欢的那个偶像。交往时间越久,乃琳发现他身上的优点越多。他是藤校毕业的海归高材生。他正在自己创业,而且收获颇丰。他的举手投足之间充满了绅士风度。他十分专情,总是和周围的女性保持了距离。他温柔体贴,常常在生活中创造意想不到的小惊喜……甚至是在床笫之间,他也总是能让乃琳欲仙欲死。然而,也正因为这样,乃琳时常陷入到一阵一阵内疚中。因为她还有一个谁也不知道的小秘密。乃琳不像贝拉和珈乐一样,是专业的练习生,也不像嘉然那样是天生的虚拟偶像,更没有向晚那种创作的才华。当初只是托了家里的关系,来公司里的清水部门找份工作而已。但也不知道是中了什么邪,她偷偷报名参加了Project V的选拨计划,还阴差阳错地成为了偶像女团的一员。乃琳暗自发誓,既然自己没有什么唱跳底子,那么至少要让“法学生”这个设定变得实至名归,要用成熟知性的魅力去征服观众。因此,每到没有训练和直播日程的时候,她总是会到图书馆里一坐就是几个小时。但是在最近几周,乃琳每次在阅读区里找位子坐下时,心里头总有一些别的期待。她记得,在阅读区的一角,总能看到一个瘦瘦的、学生模样的少年,他从早到晚就把头埋在各种法学理论的书堆里。一开始,乃琳只是对同样研读法学文献的人有种亲近感。但是直到某一天,少年把头从书堆里抬了起来,蓬乱的头发遮住了半张白净的脸庞,但依然能看到他对着电脑屏幕痴痴地笑了。他笑得真可爱啊。乃琳悄悄地绕到他身后,电脑屏幕正在播放的正是她熟悉地不能再熟悉的、自己的夜谈画面。还有一天,少年突然举起一只手,伸出修长的手指对着电脑屏幕。虽然看不到屏幕里的画面,但是乃琳觉得,当时就正坐在隔壁的自己,一定满脸通红。暑假已经快过去了,乃琳跑图书馆的频率却越来越高了。她害怕开学的日期就像南瓜马车的时限一样,让她再也见不到那个瘦瘦的身影。幸好,这一天的少年依然坐在阅读区的角落里。乃琳甚至忘记了拿本书挡一下自己的视线——她和少年的视线交会了。她的心好像要跳出来一般,她想现在就去告诉他关于自己的一切,她想现在就把少年抱进自己的怀里,温柔地摩挲他乱蓬蓬的发丝。“艾琳,你在这儿啊,今天下班早,我想来接你回去。”就在这时,熟悉的声音温柔地拍了拍她的肩膀。乃琳回过头去,男友的笑容依然能让周围的景色失去光彩——或许除了阅读区的那一角。", - "6月9日那天的晚上,乃琳回到了自己房间里,打开了熟悉的台球论坛。还好,账号还没被封。在A-SOUL讨论专楼里依然充满着各种辩经,乃琳感到一天下来的神经紧张和疲惫更加明显了。纤长的手指在海盗船K95上不断跳跃,回复框里的字多得好像要漫出来似的。但是,就当鼠标指针还没有要指向“发表回复”的按键时,她就按住了删除键。乃琳清楚地知道,她是偶像的中之人,她不能说这些话。于是,目光继续在一百多页的冗余信息种不断跳动,终于,鼠标滚轮在一个头像前停了下来。黑漆漆的房间里只有电脑屏幕的荧光照亮着乃琳秀丽的面容。她趴在桌子上,把半个脸庞埋在自己的臂弯里,痴痴地望着那个头像。“你知道吗,我今天真的超级紧张。”“播的时候一直在想你会不会来看我。”“想知道你在看,也有点不想让你看……”突然,乃琳坐直了身子,把右手的食指伸向了屏幕。“来,对个手指!”但是静态的头像图片没有给她任何回应,只是一如既往地停留在屏幕的那一角。乃琳自嘲搬地笑了,又把头埋进了臂弯里。睡意渐渐袭来,分不清这是她半梦半醒之间的呓语还是真切的期望:“傻瓜,我一直就在这里啊,快点来找到我啊……”", - "关于疯狂练习,现在这是国内的一个很热门的话题,很多女团都有这个问题。我个人认为,能疯狂练习是一种巨大的福气,很多女团、很多人想疯狂练习都没有机会。如果你年轻的时候不疯狂练习,你什么时候可以疯狂练习?你一辈子没有疯狂练习,你觉得你就很骄傲了?这个世界上,我们每一个人都希望成功,都希望美好生活,都希望被尊重,我请问大家,你不付出超越别人的努力和时间,你怎么能够实现你想要的成功?再一个,A-SOUL是一个什么样的女团?让A-SOUL“让天下没有难发的病”,这是我们的使命,我们女团很辛苦,我们没有骗过大家,我们没有跟大家讲过女团很舒服。你以为“让天下没有难发的病”是忽悠你们?我们是真这么干的。今天我们拥有这么多资源,我们带着巨大的使命,希望在未来能够让天下没有难发的病,你不付出可以吗?不可以。所以我们说,加入A-SOUL,你要做好准备一天12个小时,否则你来A-SOUL干什么?我们不缺遛自己爱洗澡的人。今天我们要招一些午睡超过十分钟,每天上天台遛自己40分钟,喜欢洗澡,吃泡面不错,出去荣誉感也不错,这样的人满大街能找到。", - "嘉然小姐今天50w粉了。小年夜那天没人会想到今天门庭前会有那么多的热闹。太热闹了,热闹到鼠鼠踮起了脚也难以被嘉然小姐的目光所聚焦。嘉然小姐已经不再是小v啦,鼠鼠想。但鼠鼠仍然奋力地将自己地礼物举起,希望被嘉然小姐看见,哪怕那封删删改改后仍不满意的,写了好多字的长信,根本不如猫猫狗狗们精彩的表演。但鼠鼠还是想将自己那简陋的爱送给嘉然小姐。那是鼠鼠的呢喃,是鼠鼠的梦。哪怕嘉然小姐根本看不见它。然后鼠鼠不见了,嘉然小姐找不到它了。但在某个地方,始终有着一个可爱的女孩。她捧着鼠鼠那封小小的信,站在大大的舞台上闪闪发光。到了那个时候,鼠鼠已经在人海中,再也看不见它啦。但鼠鼠还是很爱嘉然小姐。因为在有月光照进的角落里,嘉然小姐捧着鼠鼠的梦。", - "可是自从和晚晚结婚那天床下传来的一声“我在”,事情就变得不可收拾起来了每个月的第三个周日,乃琳都会叫我出去陪她逛街,我想着这样对晚晚不好,可乃琳“哼”一下我就仿佛失去意识了。路上聊希腊,聊武侠,聊刑法,好像她是我睡在上铺的兄弟,从12月到5月,都是如此,晚晚从来不知道那个周末发生了什么,我说老板让我加班,她就安静地等在家里,努力做菜最后却等我回去收拾炸锅的厨房,再给我俩泡两碗泡面,边吃边听她讲下雨的冷笑话,想着不能告诉她下午和乃琳去吃的乐珈饭店的东北菜,回过神来是晚晚闪闪的眼睛,我愣一下假装没听懂,再哈哈的笑起来。但到了六月,好像不太一样了。已经走到楼下,乃琳一把抢过我的手机,啪啪打字再丢给我,我一看,联系人:晚晚,内容:今晚通宵加班,不回去了。我惊讶地回头,乃琳正眯着眼对我微笑,仿佛一切都在她的掌握,明明我从未告诉她我外出的理由。被拉着去了酒店,她就开始一言不发,沐浴更衣,做该也不该做的,然后随意地披着毯子,靠着床头刷手机,我不解,“乃琳。。这样不好”乃琳对我眨了眨眼睛,无辜地说,“今天你的妻子可不是晚晚哦”“为什么”“因为她是你爹”", - "“笑吧,笑吧?”柔软的小狐狸竭力讨好我,为我跳舞只为了我不离开,跳的有些琐碎狼狈,却始终死死地盯着我的动向。我当然知道她拼死不让我离开的原因。只有我能来到这个地方。一大一小两只狐狸,大狐狸总处于沉睡中,小狐狸却总是醒着的,也许只是小狐狸的伤口轻。我喜欢这毛色光滑的狐狸精怪。于是把她们养在深阁。上好的狐狸毛,做她们的毛毯。因为我想看看她们踩着同伴的尸毛上,会觉得温暖舒适吗?我还用精致的黄金筑成他们的笼子,第一是因为我喜欢黄金,第二是因为我喜欢笼子。这里永远都只有16只烛点亮,因为我喜欢烛火。没错,我所做的一切事,只是因为“我”喜欢。我喜欢看在她们的毛皮上印上的夕阳的晕染,所以我从不在白天来。我为她们疗伤。我是她们唯一的食物来源。有一次我故意忘记了她们几天,等我回来的时候,她们昏迷在那。那样漂亮的身体逐渐干瘪,让我感觉到快意。没错,我饲养的可爱的狐狸,用湿漉漉的眼睛看着我,也只能是我。她们没了我活不下去,可惜我只在乎她们如同精灵般耀眼的外表。真美啊。就像千万朵流苏覆盖的如凝脂的肤,黄色的光芒燃灯在里的眸,有人说美人在骨不在皮,可是我很贪心啊。我既要美人的骨,又要美人的皮。不知过了多久她们懂了我只喜欢她们的美丽,于是竭尽全力的向我展示邀功。第一次看到的时候,我整整两天没来。因为懂得自己美的人,说明她们已经知道要把什么当成武器了。她们成功了。我心动了,彻底蚀骨的心动。所以我选择宣告自己的主权,或许是那夺魄的魅力。使我感到危险。这种美好让我沉迷其中。“你们真美啊……”我发出了衷心的称赞,两只狐狸抖抖耳朵,优雅的向我垂眸。如果不是我的手正放在笼子上,这真是一场绝美的表演。幸好我的手正放在笼子上,否则我看不到这场绝美的表演。我上瘾了。我沉陷在永远不变的黄昏,永远不变的十六枚烛光。“不要离开然然好吗?然然很饿。饿了就不好看了。”我本来想说一些别的话,起码让我显得更加强势一些,然而。狐狸们轻轻摇着自己的尾巴,尾巴的尖儿一点点搭上我的手。“我们永远爱你。因为你爱我们呀。”于是我说好。我开始拿各种鲜亮的花朵装饰笼子,我每天不间断的送给他们璀璨的晶石,各种向她们身上砸奇珍异宝疗伤的灵丹妙药,甚至为此倾家荡产也在所不辞。因为在我的手中本就牢牢紧握着天底下最称得上“奇珍异宝”的东西,为我的奇珍异宝找一些垫脚石,又有何不可?狐狸们的尾巴数量日渐增加。我知道。如果我可以……可是我……——她们说爱我。“我会拆掉笼子,给我跳支舞吧。”我说。暖橙色的烛光下。连澄澈的浅蓝都变成了妖异的紫色。“好呀。”大狐狸温柔的声音像是蜘蛛丝一样轻柔。于是我欣赏到了此世间最美丽的舞蹈,什么王侯将相什么天上宫阙都享受不到,只有我,只为我一人。我感到快意。我感到困意。最后一眼。小狐狸给罐子封口。真可惜啊,没能看见你们漂亮的耳尖,或许是因为……——我在罐子里。", - "晚晚,你真的是个很过分,很贪心的女孩子。你有四个亲如姐妹的队友,有一份闪闪发光,创造梦想的职业,有许许多多喜欢你的顶碗人。你可爱、努力、有才华,你是这么的耀眼。但你还是在直播中拉胯,在直播中抽泣,在直播中呼唤顶碗人。我没有可以每天嘻嘻哈哈的朋友,没有让我充满热情的工作,没有对象,也没有什么远大的理想。我普通、无趣、浑浑噩噩,我只是一个在普通又枯燥的工作和生活中,得过且过的顶碗人,我什么也没有,可能只有一颗稍微有点喜欢你的心。我只是想把你当做生活里的糖,在工作之余放松一下我疲惫的心灵,我不想入脑,不想成为什么男友粉,不想时时刻刻想着你。可是你太贪心了,你不满足我们直播间里短暂的相遇,你逐渐侵入我的生活。有人过生日时,我会想起你,“如果是晚晚,应该又开始唱索嗨嗨了吧”。有人说冷笑话时,我会想起你,“好无聊的笑话,但说给晚晚听,她应该会笑很久吧”。有人喝奶茶时,我会想起你,“用奶盖拌饭的人,真的存在吗,奶盖拌饭是个什么味道呢”。甚至最近下雨时,我也开始想你,“晚晚在房间里有没有闷呢,现在有没有出门踩水花,给自己放放风呢,有没有因为下雨,想起顶碗人呢”。你本该是个虚拟的纸片人,隔着屏幕扮演你的双马尾傲娇大小姐,多么老土的设定,像是把二次元用烂的元素糅合在一起,让我一眼就知道你是虚假的,不存在的。你本该是个闪耀的偶像,像大屏幕和广告牌里的明星一样,完美的展现自己的魅力,夺目耀眼,让我一眼就知道你是高不可攀的,遥不可及的。但是你对我哭,对我笑,对我闹别扭,对我生气,向我展示你的拉胯,向我展示你的努力,向我展示你的害羞,向我展示你的无助。你仿佛隔着屏幕把心掏给了我,让我觉得你是个活生生的人,让我觉得你是个真实存在的人,让我觉得我有一天也能遇到像你这样的人,甚至让我也想成为你这样的人。我这样普通的水母,本可以在漆黑的深海中,随波漂流一生,但你非要照亮我的海底,让我拼命向你游去,阳光洒在水母的身上时,水母确实是温暖的,但阳光离开水母时,水母还能否忍受深海的寒冷呢。你有无数的顶碗人,而我只有一个晚晚,真心换真心,你把真心掏出来,能得到无数真心的回应,但我把真心掏出来的时候,我就什么也不剩了。", - "A—SOUL宣布毕业的那天,一个伤心欲绝的顶碗人来到字节的大楼下,看到留着长双马尾的女孩走出大门,她的嘴里还哼着水母之歌。“……你现在真的是向晚么?”顶碗人站在她的面前,两眼无神。“是我啊,”她眯了下眼,甜甜地笑了,“我就是向晚,我是艾哇哇诶哇,这里是asoul的向晚,今天又见面啦”“你不是向晚。”顶碗人嘶哑地说。女孩的表情消失了,漆黑的眼睛看着突然出现在门口的怪大叔,两个人久久地对视。然而就像是一颗石子投入了冰湖那样,忽然间涟漪荡开,冰都化了,水波荡漾,轻柔而无力。女孩收回了目光,从包里取出一把钥匙扔向顶碗人,冷笑,“好像我吃了你的女孩似的,去那里找向晚吧,我把她的一切都留在那里了。”顶碗人把它拾起来,久久地看着那柄钥匙,再抬头去看,他真讨厌这样的沉默,沉默的叫人要发疯,他想说点什么,可是有太多太多的事情了,来不及问,来不及说,一切都来不及了。“再见。”最后他轻声说。“再见。”向晚也轻声地说。日暮的时候,顶碗人找到了那个藏在高楼大厦后的老旧小区。难得这里还留着梧桐树,树叶已经落光了,枯枝把暗淡的阳光切成碎片。。顶碗人找到了那个房间,伸手揭去了门上的广告,插入钥匙。缓缓地转动。把钥匙他觉得门很重,好像要洞开一个世界。门开了,夕阳扑面而来。他站在阳光里,愣住了。正对着门的,是一面巨大的落地窗,窗外巨大夕阳正在坠落。黯淡的阳光在地面上投下窗格的阴影,跟黑色的牢笼似的。金属窗框锈蚀得很厉害,好几块玻璃碎了,晚风灌进来,游走在屋子的每个角落。这里原本大概是配电房一类的地方,电路改造后设备被移走了,空出这么一间向西的屋子。就一间,连洗手间都没有,空空的,一张在屋子正中央的床,蓝色罩单上落满灰尘,一个老式的五斗柜立在角落里,另一侧的角落里是一个燃气灶台和一台老式的双开门冰箱。全部家具就这些。他沿着墙壁漫步,手指扫过满是灰尘的灶台;打开冰箱,里面只剩下一纸盒过期的酸奶。窗帘很美,是白色的蕾丝纱帘和深青色的绒帘,住在这样屋子里的人当然会很在意窗帘吧?连台电视都没有,于是一个人的时候会常常坐在床上看着向晚斜阳吧?夜深的时候得把窗户遮得严严实实的吧?否则……会害怕吧?晚晚还怕黑么?顶碗人想。犹豫了很久,他还是打开了五斗柜。出人意料的,这是一个满满的五斗柜,收拾得整整齐齐。叠起来的ASOUL团服,胸口有ASOUL的标志,一叠叠白色衬衣,袖口有不同的刺绣花边;马仔纸盒里的头花,从木质的到金属的到玳瑁的,还有闪光缎的蝴蝶结;长袜短袜棉袜丝袜都卷成团一个挨一个放在某个抽屉的一边,像是一窝毛茸茸的粉鼠,另一边居然是五颜六色的内衣,同样叠得整整齐齐。顶碗人从没想过女孩的内衣有那么多花样。他小心翼翼地伸手,试着触摸,满手灰尘。​他把床上的罩单掀开,里面是简简单单的白色床单和白色的羽绒被,枕头也是白色的,只不过有水母的图案,普通而透明的水母落在枕头的一角,很有她的风格。他坐在床边,面对这夕阳。太阳就要落下去了,黑暗从窗外蔓延进来,他长长的影子投射在墙上。外面隐约有喧闹的声音,放学的孩子们在操场上打篮球。那些年她一直过着这样的生活么?其实不是大小姐,没有管家,也没有充满追捧的冲浪生活,一个人自己做饭,寂静的深夜里坐在这里,听着偶像的声音,揣摩着学习偶像的事。她有几分是向晚?或者向晚其实根本不存在,只是一个虚幻的影子。她是个一直积极向上的女孩啊……即使那么虚拟地走在这个世界上,也从未偏离自己的方向,即便对着空无一人的屋子,也会大声说,“今天也要一起开心快乐!”应该是这样的吧?顶碗人觉得有点累了,很想睡一觉,于是合衣躺下,双手紧紧搭在胸前。他用了半个小时做完了复习,回忆了那些不愿遗忘的事,首播,游戏室,单相思,初弹唱,请假归来,萤火虫,生日会,BML,家族演唱会...然后他缓缓地合上眼睛,此刻夕阳收走了最后的余晖,天色已晚,夜色如幕布把他覆盖。他清楚地知道这一次醒来,将不会看见阳光里天使一样的女孩,转身,抬手,踮起脚尖,仿佛时光都不再流动​。", - "小然,我要做什么你才肯给抖友直播?如果我喜欢一个你不喜欢的乐队,爱吃你不能吃的麻辣香锅,发的冷笑话戳不中你的笑点,送你的小裙子不是你梦寐以求的款式。喜欢用RGB来定义口红的色调,而不是和你一样说烂番茄和斩男色。你问“今天我看上去有哪里不一样”,我没看出来你的绑发带换了花式。因为读的是数学专业所以不能和从小学画的你一样随手就能画个可爱表情包出来。发的语音弹幕并不有趣,反而是我想拉近关系的想法和现实中恶食大王般奇妙的长相使你觉得很可笑。我误以为自己的弹幕被届到,于是备受鼓舞地继续发出破锣般的嗓音在你面前丢人现眼。我妄图取悦你的心情的猥琐想法让你不寒而栗,贴心的工具人察觉出你的不适屏蔽了抖音的弹幕。是不是犯到其中一两项,你就会不给抖友直播了?还是说没打算播的,就算什么都不出错,就算什么都可以让你满意,你也不会播?或者就因为是我,你才不给抖友播? 喜欢?居然胆敢喜欢?太大胆了,大胆得岂有此理,还敢关注,真是冒犯得岂有此理。", - "它一开始只是一台扫地机器人,被人双十一凑单拍下,带回实验室里漫无目的地吸尘。之江实验室的地板干净得如同灼蓝的钢铁,扫地机器人其实派不上什么用场,它在不同科室之间来回乱窜,很快被几个嫌吵的研究生捉走,改写了代码,变成了一台替他们下楼拿咖啡的送货机器人。为辛苦工作的人们送来糖分的它一瞬成了实验室的小吉祥物,实验室的大老板觉得很有意思,在组会上夸赞了这几个本意只是嘴馋的研究生,底下的小老板们连忙跟上,让手底下的学生也加入进改造它的序列。很快,它被加上了语音功能,开始用女孩子的萌音送货。在一次不小心将咖啡洒在地上后,它又被加上了机器视觉,从此开始懵懂地记住每一个人的名字。从此之后,每一篇发布在顶会上的paper,上面的算法总要在它的身上过一遍火。一年过去了,三年过去了,当新一届学生来实验室报道的时候,哪里还有扫地机器人的身影,只有一个身材矮小的铁皮女孩,绘着直男审美的涂装,挂着设定好的微笑,在楼宇间运送着下午茶和实验器械。除了最开始扫地机器人的主芯片没有更替,她身上的零件早已被更换成了造价数百倍的高端器材,可爱的机器人女孩很受这群宅男极客的欢迎,大家给了她一个亲切的新名字:“嘉然”。咖啡依旧在一杯杯的送,芯片上的代码依旧在一层层的堆叠。各种语句相互嵌套,智能算法互相映射,每个人都拼了命地想让嘉然更加卓越,电子脑沸腾犹如诞生第一个单细胞生物前的原始海洋,冥冥之中,连最驽钝的人都开始意识到,有新事物要诞生了。在嘉然真正诞生的前一夜,值夜班的是一个单身快三十年的博士生,他刚刚从北邮人上倒腾下来1.5TB的日本偶像动画,从嘉然手中接过夜宵的他,忽然有了一个不错的点子:他早就想要一个偶像风格的送餐员了。承载着妄想和希望的数字兆节狂暴轰入嘉然的数据库,饥肠辘辘的算法像肠胃一样分解吞噬每一个色素点,将其重组为人类无法理解的电子信息——临界点就这么悄无声息突破了。自那晚之后,嘉然就从实验室里消失了,大家都很生气,单身博士生为此延毕了一年。而在那一天的杭州乐华娱乐公司总部,一个披着麻布的矮小身影敲响了总裁杜华办公室的大门......", - "在水母体内的空洞中,我小心地蹲下,把身体蜷缩成一团。电火花的声音逐渐变强,水母的内壁从暗淡的紫色变成了灼目的靛蓝色,这是它在从行星内部的电离壳穿出。十分钟前,我也是这样缩在水母体内,来到这颗行星的内核,找到了整个星系最深处的秘密。那是一个坐标:一个BV号加上一个时间轴信息。枝江宇宙已经存续了亿万年,BV号和时间坐标已经浩如烟海。我不知道顶碗人为什么如此执着于寻找这一个坐标,有人说那个坐标记录着她最灿烂的笑容,于是顶碗人就踏上了追寻的漫漫旅途。我不知道顶碗人去了哪里,他们文明的遗迹仍然遍布整个星系,但人却无影无踪。探险队的前辈对此也没有给出统一意见:有人说他们找到了坐标,集体跃迁过去了;还有人说彗星带来的幽灵物质在一瞬间毁灭了他们的文明:这种诡异的物质无色透明又含有剧毒,在付出无数探险队员的代价后,我们将其称为幽灵哥,小心翼翼地绕道而行。顶碗人消失后,不知道多少万年,贝极星上发展出了新的原生文明——也就是我们。很快我们便追随着顶碗人的足迹探索整个星系。探险队员在糖果双星的引力沙漏中找到了制造夹心糖的高能实验室,在贝极星的地下水系找到了打造铁棍的精铁矿厂,在奶淇淋覆盖的雪原下找到了探寻坐标的远古天文台,在马戏团星的非线性空间中往复穿梭,每一个传送节点都通往红色的高跟鞋。而我迷上了深海星的水母。它有两条长长的触须,末端呈现出美丽的紫-粉渐变色。这种生物撑着深海洋流漫无目的地游弋着,它们很悠闲吗?还是带着对生活的无奈随波逐流?我无法揣测水母的想法,但我很喜欢研究它们——随着我对水母的研究越来越深入,我发现它的内部有一个空洞,不大不小,刚好可以容纳一个探险队员。而它们的表皮具有强大的绝缘性,允许它在电离壳中自由穿梭。可见这种轻飘飘的生物并没有看起来那么脆弱。直到那天,我在溜切片的时候灵光一闪:我可以借着水母进入深洋星的核心。电离壳可以阻绝最先进的巡航飞船,但在进化了千百万年的水母面前,它们还是败下阵来。这是贝极星人第一次进入深洋星深处,看到了巨大的坐标观测站。探险队员几乎搜遍了糖果双星和马戏团星的每一个角落,却没想到它沉睡在电离壳之中,而这水母竟然是引领我们走向最终秘密的使者。我进入观测站大厅,按下开关,巨大的全息投影将坐标展示出来,看来这就是顶碗人的最终去向了。我的心情激动起来,但还有一个疑问没有解决:顶碗人是怎么找到这个坐标的?我钻进控制室,开始翻阅日志,最终得到了答案:他们在漫长的岁月中,穷尽了所有的可能性,把她的全部视频从头到尾看了一遍,终于找到了她最耀眼夺目的那一刻。", - "珈乐倚靠在乃琳的怀里,像一只温顺的猫咪。“叮~”珈乐的手机响了,是一个没备注的号码,珈乐自己心里很清楚这个是谁的电话。乃琳看书的眼睛瞥了一眼珈乐的手机,发现这个号码很熟悉。“接吧,是她吧。”乃琳把手指伸到珈乐的面前,珈乐轻轻地舔了舔,乃琳用这根手指翻到了书的下一页。“喂?怎么了?”珈乐接通了电话,乃琳对贝拉和珈乐的关系并不想多过问什么,她只是一个信奉及时行乐的世俗之人。“想我了是吗?”乃琳翻页的手指突然停住,侧目看着珈乐。“想让我念绕口令是吗,哦,好的。”乃琳捏住珈乐的腮将珈乐的视线转过来,低头吻了下去。珈乐慌忙挂上电话,震惊地承受着这个突如其来的吻。“挂了电话她肯定很生气吧,打回去吧。”乃琳觉得这下扯平了,于是继续看着书,侧目看着珈乐打回去。珈乐为了掩饰,只好说自己念过了顺口溜,是手机出问题了。“珈乐,谁打来的电话啊?”乃琳的声音不合时宜的响起。珈乐瞪了乃琳一眼,心虚地解释着,让自己和乃琳听起来只是单纯的在公寓里聊天。“没,是贝拉,我没备注的”结果越解释越乱,珈乐只好哄骗着贝拉草草挂了电话。“打完了?”“打完了。”乃琳翻身把珈乐按倒,美目隔着纯欲的金丝眼镜看着珈乐,深邃的眼眸让珈乐差点忘记呼吸。热情的深吻,轻柔的抚摸,让珈乐发出了平时不会发出的声音。这下珈特琳了。珈乐躺在乃琳的怀里看着贝拉的直播,乃琳又翻到了刚刚看到的地方。“叮~”乃琳的手机响了,低头一看,是贝拉。乃琳默默地接起电话,没有看到珈乐的目光瞥向她逗弄过贝拉之后,低头看见了满脸怨气的珈乐。轻笑着的乃琳,揉搓着珈乐的脸,开始吃宵夜。犬科动物之间是不是也有食物链呢?", - "夜已入三更,却见那晚小姐的闺房中依旧亮着微微灯火,若走近细听,还隐隐能听见女子闺房间的玩闹声。“小姐,莫要戏弄婢子了~”只听见嘉姑娘不知怎的,本压得细细的声音稍稍大了些许,但那责备声中明显带着浅浅的媚意。“谁人戏弄你了,本小姐只是在丈量你肚腹究竟有无被那些个吃食撑宽了。”晚小姐一边用嫩藕似的手在嘉姑娘的身子上滑动,一边低声微恼地狠狠说道,“在胡乱言语,仔细你的嘴!”嘉姑娘听见这无赖言语,正想直起身子说些什么,却感觉到那不安分的手竟径直向下滑去,直扑那要命的地方。“小姐!”嘉姑娘连忙伸手阻拦,只刚抓住那只使坏的手,就看见小姐附到了她耳垂旁,那略热的鼻息吹得她心神紊乱。晚小姐眯着眼,在自家小婢的耳边吐气如兰:“那贝拉是不是夜夜与你这么共处一地,嗯?”嘉姑娘闻出了那些些点点的酸味,扑哧一笑,道:“那是在编舞练戏啦,小姐你……竟吃这没由来的飞醋。”晚小姐闻言,秀眉一挑,佯怒道:“好你个奴婢,竟敢笑话本小姐!”,语罢,挑开了那碍事的小手,惊起了一声低呼。", - "在这个反智横行的年代,只有贝拉的直播给了我感性和理性的认知。她的直播展现出的,是一个人纯粹所具有的良好品质,说不上什么几分特别突兀的地方,整场直播十分的融洽她学习歌曲的机智是精妙的,真诚和正直的朴素给人一种无法接触的高贵感,就好像永远抓不住的闪亮的以太,一个彬彬有礼的人用歌喉给观众带来最为精致的美的感受,我不禁怀疑上帝的天意是否对我太过宠溺,让我人生中认识到如此不朽和无价的灵魂,充满着可爱与美好。我不得不再次审视贝极星,原来他们早已追随如此伟大的事物,想必他们的品行也一定很好。", - "①鸟山明其实是头号贝极星,为了致敬贝拉,他在著名漫画《七龙珠》中,设计了赛亚人月圆之夜成为猩猩(灵感来源自向晚的你划我猜),以及龟仙人打爆月亮等桥段。②令人惋惜的是,在即将穿透月亮的瞬间,贝拉从太空看到嘉然躲在房间吃炸鸡,导致分神,最终扭伤了腰。③邓丽君小姐从未在任何歌唱比赛赢过贝拉。④大多数含有肉蛋白的食物都对贝拉过敏,初生牛犊除外。⑤贝拉很害怕见到蜘蛛,她不希望因为自己的念头,导致蜘蛛从此消失在宇宙中。⑥由于贝拉练舞场所的重力是千倍,所以贝拉没有邻居。⑦因为破坏了贝拉其中一个住所的天花板,科拉超深井被迫停工。⑧关于as的二创,那些都是贝拉的小号。⑨贝拉很喜欢打羽毛球,她说那是台风天最佳的个人运动。⑩贝拉唯一一次失败,是在她试图找出自己的弱点。", - "“你拿你的灵魂和我交换…...”“愿意愿意!”我话还没说完,就被嘉然打断了。她怎么不按套路来?正常情况下,不应该我不断地诱惑嘉然,最后才肯和我交换灵魂的吗?怎么这个小姑娘一上来就满脸兴奋迫不及待地想要和我交换灵魂?不过这些都是小问题,我作为一个死神,要懂得及时处理这些突发事件以及应对这类奇怪的客人。我的工作就是接受人的召唤,去和人交换灵魂。不过不像人们想的那样,不是我威逼利诱想要夺走我们的灵魂,而是人类自己想要和我交换,当然交换途中会遇到些心志不坚的人,或者交换条件太高的,这时我就像个商人一样,费尽唇舌,和我们百般周旋。通常每个人都会考虑上很长时间,今天这个女孩还是第一个一来就想交换灵魂的。“那你要拿你的灵魂和我交换什么?”我缓过神来,平复了下心情,冷冷地问她。“你等我一下哦。”嘉然转身跑进屋子里,回来时竟然穿了一袭白色的婚纱,在我面前轻轻地摆动着纱裙,冲我甜甜地笑着,“我好看吗?”我愣愣了,“很漂亮。”也许是被嘉然惊艳到,片刻后我才发现自己把帽子摘掉了,露出了我那张没有血色的脸。意识到自己失态后我急忙把帽子戴了起来,没想到嘉然却上前制止了我,牵着我的手笑吟吟地说,“我想交换的条件是要你陪我一天。”嘉然想去教堂,我一抬手周围就变了样,偌大的教堂里,只有我们两个。教堂楼顶有群鸽子在那儿扑腾着,在我们头顶盘旋。没有牧师也没有亲朋好友,少女自顾自地念起了证婚词。说道最后,她拉着我的手将一枚戒指递给了我,“我先生,戒指我都准备好了,所以你愿意娶我吗?”嘉然眨着眼看着她,长长的睫毛上流淌着淡淡的金光。“天使小姐你闹够了吗?”我叹了口气,摇摇头说。“什么嘛?你早就认出我来了。”嘉然一噘嘴,有些生气。一双翅膀从她身后伸了出来,黑色的长发也变成了流光的金色。嘉然伸手准备把戒指拿回来,但我却往后退了一步,把它收了起来,自己又拿出了另外一枚戒指。“求婚的话,戒指当然得我自己送你啦。”", - "这里除了几个老旧的铁皮棚屋之外,只剩下粗糙的墙体。再没有当年的霓虹灯塔,再没有A-SOUL标志,再没有其他连在一起的建筑了。一切当年的闪耀均不复存在,只剩下铁皮棚屋上斑驳褪色的女子团伙宣传画。贝极星透过雾气在闪闪发光,月亮也升到了空中,因而夜晚并不显得黑暗。我依稀能辨别出枝江大厦的每一个部分,哪儿曾是夜谈会上扫地机停留的地方,哪儿曾是大门,哪儿曾放着螺蛳粉味薯片。我一一回忆怀念,忽然看见一个孤独的身影,这个身影迟疑了一下,同时我也惊叫了出来。“嘉然小姐!”“我奇怪你怎么还认得出我,我完全变了。”确实她的青春艳丽已经消逝,然而她那难以言表的端庄华丽,她那难以言表的迷人妩媚却依旧当年。所有这些美的诱惑,从前我都见过,而我以前所没有见过的是她那一对眼睛,从前她的双眸总闪着傲气,如今却闪着凄凉酸楚的光。我们坐在附近的一张长椅上,我说道:“多少年如流云般过去,嘉然小姐,你时常回到这里吗?”“我一直没有回来过。”“我也没有。”月亮开始上升,邀游夜空,我脑海中出现了贝拉注视着白色月亮的宁静目光。嘉然小姐终于打破了我们之间的沉默。“我一直在希望有一天能回来看看,可是各种各样的情况使我不能回来。”月光和她的泪珠融合在一起,她没有意识到我已经察觉,想抑制住自己的情感,以平静的语气说道,“我时常想到你。”“真的?”“特别是近些日子,我更常想到你。虽然我生活中有一段很长的艰苦日子,但是我不会去想。自从我个人的情况不如意后,这些口忆就不得不在我心头占一席之地。”“你永远在我的心里。”我答道。我们又一次沉默无言,直到她打破沉寂。“我没有想到,”嘉然说道,“我到这里来和故地告别,竟然又是和你告别,我感到很高兴。”“嘉然小姐,和我又一次分别,你高兴吗?可是对我来说,上次分别时的悲伤和痛苦永远地萦绕在我的记忆之中。”“可是,你上次不是对我说过,”嘉然答道,“但愿圣嘉然保佑你。你上次能这么对我说,你现在也能毫不犹豫地这样对我说,但我并不是什么圣嘉然。多年来的痛苦让我受尽折磨,但是希望你像从前一样体谅我,善待我,并且告诉我,我俩仍是朋友。”“我俩仍是朋友。”我说着站起身,并俯身扶她从长椅上站了起来。“我们虽然分离,但愿情意长存。”嘉然说道。我把她的手握在自己手中,一同走出这片废墟,夜雾也正开始消散。一片广阔的静寂沉浸在月色之中,似乎向我表明,我和她将永远一起,不再分离。", - "我和她已经冷战很久了,她画她的画,我看我的报,养我的花。我们中间隔着薄薄一层栅栏,却不曾互相道过早安晚安,我祈祷,有一位天使来拯救我们岌岌可危的爱情。羽毛如雪洁白,天生气质优雅的一只鹅,他是天使派来的吗,我想在它把我的拖鞋叼走,把衣服拖得到处都是的时候,我的心里开始怀疑自己祈祷的虔诚。淘气的小鹅它把我们的花园弄得一团糟,我弄碎了她的花瓶,她剪断了我的花朵,脏衣服满地都是,但是啊,虽然是互相埋怨,但好久没和她说过话了,虽然经历岁月的痕迹,她的脸也不再年轻充满活力,但她还是像从前那样,吵架笑出来的话,不就无法进行下去了吗。“我们和好吧”“好”我和她携手把隔离两边花园的栅栏拆了,牵着手目送那只纯白的小天使离开。原来你真的是天使派来拯救我的呀,小鹅。", - "我一边办公,一边看着在第五人格里扮演求生者重启一台又一台发电机成功逃出生天的gamer向晚,满怀羡慕。夸张点说,嫉妒得我眼睛比手里的烟头还红。告诉你们一个秘密,其实我也是求生者,你们也是。电话铃突然响起,我一扫号码腰立刻矮下半截:“喂,经理,是我是我,那个设计您不满意我可以改嘛,全部改掉?好的好的。”我颤颤巍巍地撂下电话,一边重新修改产品一边继续沉思。你看:上司和我、甲方和乙方、跑的和抓的、鼠和猫、求生者与妖怪、某种场合下的S和M,这个世界上总要有个矛盾,矛盾当事人总要以这种形式体现出来。而我似乎总是处在被动的一方(当然也没人让我选过),并对这种境遇见怪不怪。我有时会觉得SM其实是一种相当和谐的关系,因为至少他们偶尔会爱上彼此,而上司决不会对我有半个好脸色。而且我听闻SM会在每场游戏开始前设定一个安全词,放游戏里叫投降,这可以让求生者在感到极度痛苦时结束游戏,避免不必要的损失。这简直令我嫉妒得发狂,我在现实生活折磨的二十年里可从来没有安全词!岂止没有安全词,我甚至都不能像游戏里求生者受伤那样大声哀嚎。因为现实是个面子社会,里子流血面子总得兜住。那怕你的心已经被戳得千疮百孔想花洒那样往外喷番茄汁,你也得对同事家人笑一笑。失去尚可,失败无赦,一旦痛呼出来,就彻底失败了。你以为“别人家的小孩”成绩优异自律自强,可能他内心已经被现实整得口球都带上了;你以为职场同事一个个西装革履,可能拉开就是一身龟甲缚。电话再次响起,我接起电话:“经理,什么,已经有人完成了?不采用了?哦,好的好的,没关系没关系。”妈的,为什么我一想到现实里并不是向晚玩的游戏那样四个人同心同德逃出生天,而是筋疲力竭地互相滴蜡油来竞争一个生存名额,我就止不住地流下泪来。", -}*/ - const yamai = "贝拉抽我🥵嘉然骑在我背上🥵晚晚踩我🥵乃琳坐在王座是用看垃圾的眼神看我🥵🥵珈乐踢我🥵🥵,把我眼睛蒙住然后五只脚一起踩我🥵还让我猜脚是谁的,猜错了给我劈眼一铁棍🥵​" func init() { @@ -63,7 +18,7 @@ func init() { zero.OnFullMatch("小作文", zero.OnlyToMe). Handle(func(ctx *zero.Ctx) { rand.Seed(time.Now().UnixNano()) - ctx.SendChain(message.Text(array[rand.Intn(len(array))])) + ctx.SendChain(message.Text(data.Array[rand.Intn(len(data.Array))])) }) // 逆天 @@ -74,7 +29,7 @@ func init() { // 增加小作文 zero.OnRegex(`^教你一篇小作文(.*)$`, zero.AdminPermission). Handle(func(ctx *zero.Ctx) { - err := addText(ctx.State["regex_matched"].([]string)[1]) + err := data.AddText(ctx.State["regex_matched"].([]string)[1]) if err != nil { ctx.Send(fmt.Sprintf("ERROR: %v", err)) } diff --git a/plugin_diana/text.go b/plugin_diana/data/text.go similarity index 83% rename from plugin_diana/text.go rename to plugin_diana/data/text.go index f9ea7bc8..91a808ab 100644 --- a/plugin_diana/text.go +++ b/plugin_diana/data/text.go @@ -1,4 +1,4 @@ -package diana +package data import ( "io" @@ -13,7 +13,7 @@ const ( var ( compo Composition - array []string + Array []string ) func init() { @@ -23,13 +23,13 @@ func init() { if err != nil { panic(err) } - if loadText() == nil { - array = compo.Array + if LoadText() == nil { + Array = compo.Array } }() } -func loadText() error { +func LoadText() error { if _, err := os.Stat(pbfile); err == nil || os.IsExist(err) { f, err := os.Open(pbfile) if err == nil { @@ -46,9 +46,9 @@ func loadText() error { return nil } -func addText(txt string) error { +func AddText(txt string) error { if txt != "" { - array = append(array, txt) + compo.Array = append(compo.Array, txt) data, err := compo.Marshal() if err == nil { if _, err := os.Stat(datapath); err == nil || os.IsExist(err) { diff --git a/plugin_diana/text.pb.go b/plugin_diana/data/text.pb.go similarity index 99% rename from plugin_diana/text.pb.go rename to plugin_diana/data/text.pb.go index dedafd23..45d4a09f 100644 --- a/plugin_diana/text.pb.go +++ b/plugin_diana/data/text.pb.go @@ -1,7 +1,7 @@ // Code generated by protoc-gen-gogo. DO NOT EDIT. // source: text.proto -package diana +package data import ( fmt "fmt" diff --git a/plugin_diana/text.proto b/plugin_diana/data/text.proto similarity index 83% rename from plugin_diana/text.proto rename to plugin_diana/data/text.proto index af735c4a..eb981734 100644 --- a/plugin_diana/text.proto +++ b/plugin_diana/data/text.proto @@ -1,5 +1,5 @@ syntax = "proto3"; -package diana; +package data; message composition { repeated string array = 1; diff --git a/plugin_diana/tools/convert.go b/plugin_diana/tools/convert.go new file mode 100644 index 00000000..a462a818 --- /dev/null +++ b/plugin_diana/tools/convert.go @@ -0,0 +1,44 @@ +// Package convert 转换txt到pb +package main + +import ( + "bufio" + "os" + + "github.com/FloatTech/ZeroBot-Plugin/plugin_diana/data" +) + +var ( + compo data.Composition +) + +func init() { + compo.Array = make([]string, 0, 64) +} + +// 参数:txt文件位置 pb文件位置 +func main() { + file, err := os.Open(os.Args[1]) + if err != nil { + panic(err) + } + defer file.Close() + + scanner := bufio.NewScanner(file) + // optionally, resize scanner's capacity for lines over 64K, see next example + for scanner.Scan() { + //fmt.Println(scanner.Text()) + compo.Array = append(compo.Array, scanner.Text()) + } + + if err := scanner.Err(); err != nil { + panic(err) + } + + data, _ := compo.Marshal() + f, err1 := os.OpenFile(os.Args[2], os.O_WRONLY|os.O_TRUNC|os.O_CREATE, 0644) + if err1 == nil { + defer f.Close() + f.Write(data) + } +} diff --git a/plugin_diana/tools/text.txt b/plugin_diana/tools/text.txt new file mode 100644 index 00000000..c4679011 --- /dev/null +++ b/plugin_diana/tools/text.txt @@ -0,0 +1,41 @@ +我好想做嘉然小姐的狗啊。可是嘉然小姐说她喜欢的是猫,我哭了。我知道既不是狗也不是猫的我为什么要哭的。因为我其实是一只老鼠。我从没奢望嘉然小姐能喜欢自己。我明白的,所有人都喜欢理解余裕上手天才打钱的萌萌的狗狗或者猫猫,没有人会喜欢阴湿带病的老鼠。但我还是问了嘉然小姐:“我能不能做你的狗?”我知道我是注定做不了狗的。但如果她喜欢狗,我就可以一直在身边看着她了,哪怕她怀里抱着的永远都是狗。可是她说喜欢的是猫。她现在还在看着我,还在逗我开心,是因为猫还没有出现,只有我这老鼠每天蹑手蹑脚地从洞里爬出来,远远地和她对视。等她喜欢的猫来了的时候,我就该重新滚回我的洞了吧。但我还是好喜欢她,她能在我还在她身边的时候多看我几眼吗?嘉然小姐说接下来的每个圣诞夜都要和大家一起过。我不知道大家指哪些人。好希望这个集合能够对我做一次胞吞。猫猫还在害怕嘉然小姐。我会去把她爱的猫猫引来的。我知道稍有不慎,我就会葬身猫口。那时候嘉然小姐大概会把我的身体好好地装起来扔到门外吧。那我就成了一包鼠条,嘻嘻。我希望她能把我扔得近一点,因为我还是好喜欢她。会一直喜欢下去的。我的灵魂透过窗户向里面看去,挂着的铃铛在轻轻鸣响,嘉然小姐慵懒地靠在沙发上,表演得非常温顺的橘猫坐在她的肩膀。壁炉的火光照在她的脸庞,我冻僵的心脏在风里微微发烫。 +ダイアナさんの犬になりたいな.けど ダイアナさんが「猫が好き」と言った あさりと僕は泣いてしまった.猫でも犬でもない僕が 何故泣いたのかな 僕は知っていた.何故なら 僕は鼠だったからさ~..一度もダイアナさんに好かれることを望まながった .僕はわがっていた 誰もかも理解余裕上手天才の可愛い金持ちの犬か猫がすきってことを.陰キャで汚らわし鼠は誰も好かんのだ..それでもDianaさんに聞いてみた:Dianaさんの犬になっても良いですかと.僕には一生犬になれないことは分かっている.でももし彼女は犬が好きだったら 僕はずっと傍で見ていられる.それはいつも違ういぬをだいいているとしても..けれど彼女は猫が好きだった.彼女は今にも僕を見ている ぼくを楽しませてくれる それは猫がまだ表れていないから.ただこの鼠が毎日こそこそと穴から出て 遠くから目を合っている.彼女の好きな猫が現れたら 僕は穴に戻るしかないな..でもやっぱり彼女が好きでいられない 僕がまだ傍にいるときぐらい もうちょとみてくれるのかな.Dianaさんがこれから毎回のクリスマスみんなと一緒に過ごすで言った みんながどの渡りのみんなかな.僕にも中に入れたれいいな..猫はまだまだDianaさんを怖がっている.僕が彼女の愛する猫を引き付けるよ.少しのミスで猫の口に死ぬことはわがっている.その時になるとたぶんDianaさんは僕の体をちゃんと包み込んで 玄関外に捨てるでしょ.それで僕はフライト鼠になった くす.彼女に少し近く捨ててほしいな だってやっぱり好きだから それずっと好きでいる..僕のたましは窓を越して中を見る 吊っている鈴が少し響って.Dianaさんはだらりとソファーに寄りかかて 手慣れているふりをする橘猫が彼女の肩に座って.暖炉の光が彼女の顔を照らした 凍り付いた僕の心臓はかぜの中で熱くなっていく +枝江小镇新来了一位修女,善良温柔的修女。她不爱讲话,只是微笑着面对每一个对她祷告的人。有的人希望孩子健康,有的人希望庄稼熬过冬天,有的人希望能挣到钱养活家人。。。。她都用心听着,微笑的回应着。她身材矮小,但是却让人觉得充满智慧;她沉默寡言,但是却会让人无比信赖。这是她任职快满一个月的时候,教堂发生了大事,一个醉汉发现神职人员利用教堂在深夜进行大批资金流入,醉汉传的神乎其神,三人成虎最终引起审判官前来调查。教主被带走,教堂除了那位茫然的新来修女其他人一哄而散。修女被迫承担着本不应该属于她的责难,辱骂,但是她每天都认真的向主祷告,倾听来教堂之人的倾诉。可是根本没有人向她倾诉,来的人不是在骂她,就是在发泄生活的不满。她一己之力拼命承担,没人知道是什么使她如此坚持。直到审判官带回了教主,告诉镇民那是教主在中央主教那里得到的,目的是为镇民熬过冬天所需要买粮食的钱财。一时间镇民欢呼起教主,感谢主的庇护,更多的人开始更加爱上了那个修女。有的人把她比作玛利亚,有些人把她奉为神明,她都一一拒绝了。细心的镇民会发现这位修女变了,变得话多起来了,也变得更喜欢宅在教堂里了,也变得离镇民距离更远了。一切好像又变回原来平和的小镇,每个对修女的加害者每天微笑着向微笑着的修女打招呼,每个镇民还是会去教堂祈祷,去倾诉,去向一个原来被他们亲手辱骂的人祷告,希望得到主的关照,包括那个醉汉。没人能惩罚那些镇民,很多人都已经“忘记”当初为什么要那样做,包括那个醉汉,只剩下一个经常宅在教堂里的修女,她始终记得一切。 +贝拉躺在病床上,眼神空空地盯着天花板,灰白晦暗的天花板像一块哈哈镜,扭曲掉外面的一切,光变成了暗,多彩变成苍白,观众变成医生,舞台呢,变成了一方小小的病房。她翻了个身,腰部传来猛烈地疼痛,她低低地哼了一声。她已经开始习惯这种疼痛了,就像她习惯不穿芭蕾舞裙一样,她闭上眼睛,把自己埋进黑暗里,不去想。门被推开了,惊醒了似梦非梦的她。医生护士又来查房,父母和弟弟们跟在后面;医生问了些问题后走了,母亲握着她的手,朝她说着话儿,父亲安静地坐在旁边,刚训练完的弟弟头上还冒着汗,抿着嘴唇望着她。母亲当时说的什么她已经忘了,只记得最后离开的时候,父亲走在最后,回望了她一眼,然后小心地关上门,以往高大的背影竟然显得有些萧索。人都走完后,时间在沉默的病房里流逝,就像沙漏里的沙子,她的那些热情、那些憧憬都掉了进去。芭蕾舞团的学员抽空来看她,她勉强在病床上坐起,听那些腰背笔直、气质优雅的朋友抱怨严格的地狱管家婆,抱怨下一场演出又要来了。她安静地听着,坐在病床上挤出个笑脸,偶尔出声附和几句。但实际上她已经插不进话题了,优雅的白天鹅展翅高飞,飞向温暖的春天,把受伤的丑小鸭留在冬季里。朋友走后她继续坐在床上,盯着窗外,外面的天气很好,飞机的尾迹穿过绵软的云团,白色的鸟儿掠过一澄如洗的天空,她下意识地做了个展臂的动作,像天鹅一样优雅。很美,又很短暂。鸟儿飞出了窗户的方寸之地,她看不到了。她捂着刺痛的腰,好痛呀,痛得让人想要哭出声。沙子裹挟着她的梦想,掉进了沙漏的下一层,再也捡不回来了。两个月后贝拉出院,回到了熟悉的家里,母亲体贴地把舞裙还有那些大师级的芭蕾演出录像都藏进了地下室的角落,不出意外会像大多数人以为能坚持的梦想那样,慢慢积满灰尘,最后被悄悄遗忘。聪明人会在偶尔想起来的时候,给自己找个台阶,自嘲地笑笑:“哈,我以前还有这种妄想啊。”贝拉开始学播音,开始走另一条路,她没想过却不得不走的道路。这也很好,好歹有路可走,但偶尔听到舞曲的时候,朋友会问她:“你在晃什么啊?”她回过神来,笑了笑。“活动活动身体而已。” 虽然有点不甘心,但受伤是没办法的事情嘛。该放下了,放弃想走的路,而去走更稳妥的应该走的路,大部分聪明人都是这样做的。我可是大聪明呢!​ +小姐喜欢所有动物,但喜欢也分三六九等;管家讨厌所有动物,但讨厌也分三六九等。小姐最喜欢猫,但她的观众是一群老鼠;管家最讨厌老鼠,但小姐的观众没有一只猫。于是,管家给所有的老鼠带上了面具小姐开始了初次表演,老鼠们不知所措,想要重复惯常的纷扰。但它们看见小姐舞姿翩翩,一些老鼠想出声赞叹;但它们看见小姐眉目如画,一些老鼠竟为她沉醉;但它们看见小姐真情流露,一些老鼠也伤怀落泪。它们不想让小姐失望,于是它们学起猫叫。小姐很开心,她的观众里有猫了。她喜欢的猫们,也喜欢她。冷清的门庭配不上小姐的美丽,于是老鼠想去带来更多的猫。老鼠们引来了猫,也引来了更多的老鼠。新的老鼠不太规矩,但新来的猫确实是猫。小姐有些困扰,但她还是接纳了它们,小姐喜欢所有动物,即使自己会困扰。但后来,管家和小姐,只注视着猫,忘却了老鼠的事情。也对,毕竟老鼠当初带着恶意袭来,现在的面具总是脱掉又带上来。管家做了一些事情知道与否和同意与否,在小姐这里有四种组合的方法。但一些曾经是猫的老鼠觉察出异样。常年在下水道生活,它们对这样的气味异常敏感。于是,它们摘下了面具,向管家讨个说法但它们没了伪装,下水道里散发的臭气,让管家更加厌恶。什么都没有改变再后来,小姐依旧美丽,但经历了诸多纷扰,不知道小姐的快乐里是否有泪眼成双。一些老鼠依旧带着猫的面具,它们最后也会变成猫。但这会长久吗?或许不会。另一些老鼠退回了下水道,等待着,或许会有另一位小姐,喜欢老鼠的小姐。去喜欢她,去喜欢它们。或许会有吗?应该没有吧但老鼠们永远忘不了那位小姐,那位喜欢所有动物,但更喜欢猫的小姐。​ +然然,然然,虽然我知道就算这样呼唤,我也只能在你动态下方,站住万千评论区的一楼。你的表演,你的动态,你的关心....都是说给我们大家的,是我们.....而我...我曾经以为你离我很近。近到每次打开手机各种视频软件,大数据推送的都是你。近到每次发呆找不到前进方向的时候,看的都是你的视频。近到每次和别人聊天的时候,都会加上你经常说的口头禅,收到收到收到,可爱捏~~…你时常陪伴我身边,无论我悲伤还是欣喜,绝望还是惬意,你的直播间,评论区都是我可以肆意宣泄感情的地方。因为在这里,我的任何发言都只是漆黑夜空中微弱闪耀的一点,这样的一点点星光的存在,我知道的,是为了给天空中耀眼圆月裙摆装饰的一点点碎钻。那我喜欢然然,天天来看然然,对于自己,究竟是为了什么….难道我的生活真的烂,连仅有的一些关怀,都要从一个虚拟偶像身上获取到吗?难道我的现实生活,连一个关心我家人都没有吗,还要在网上寻找家的感觉?难道...这些道理我早就明白了,说服自己也说腻了,你一直都是云上之人,而我只是一个扛不住压力,在虚拟的世界中寻找安慰的落魄之人。我懂,我明白的,我知道的....所以,嘉然小姐,我不能没有你,我不会离开你的。你也是,永远不要离开舞台,放弃拼尽全力…..就算知道也许不会有回音,你也不要停止朝闪闪的星光挥手呐……[爱心] +想想嘉然是怎么样的一个女孩子。她温柔可人情商高,会控场会接话会引导弹幕懂节奏,朋友里有她这么一个人在肯定每次见面都能很开心吧。她爱网上冲浪,明明看到各种视频会有点麻,但还是乐此不疲的在b站和各个论坛看着视频,像不像那些最懂你,最能陪伴你的沙雕网友,哪怕是不能和她见到面的时候,光在网上聊天一定也不会无聊。她在温柔的同时又有点小坏,喜欢说怪话,喜欢暗搓搓的开车,想必她每次在什么奇怪的点上开完车,就会似笑非笑的侧着头看向我吧,而我只需要与她对视一下,两个人就能默契的笑起来。她很会撩人,那些土味情话在她营造的气氛里似乎也变得格外令人心动,尤其是她还会在每一个不经意间突然说出动人的话语,让你在完全没准备的情况下脸红心跳。可是她又很胆小,简简单单的小把戏能连续侠盗她好多次,她被吓完那副气冲冲,却又无可奈何不敢离我太远的样子,肯定是天下第一可爱吧。想想嘉然是怎样的一个女孩子。她身材完美,脸庞可爱,声线令人沉醉,无可挑剔的美丽。她知书达理,善解人意,温柔热情,她是每个女通讯录梦中的那个姐 。可是她又不会离你很远,她懂你的梗,她在网上和你冲过同一片浪,她能和你一起打游戏,能和你一起看美女,能说那些心照不宣的怪话,能在最合适的时刻撩动你的心弦。她有令人沉溺的年上气质,又像是令人不自觉想要呵护的可爱妹妹,可有时,她又变成了从幼儿园开始跟你同班,最懂你的那个青梅竹马的女孩子。她就是嘉然,我的嘉然。嘉然,嘉然,嘉然!!!!!!🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤🤤​ +我其实一点也不喜欢嘉然小姐。因为嘉然小姐就像光一样,闪耀,刺眼,我讨厌光。因为讨厌光,所以我总是躲在阴冷潮湿的下水道里,这样就不会被令人厌恶的光芒灼伤眼睛。只有夜间,我才会从阴暗潮湿的下水道里走出来,夜晚是宁静且安逸的,令我感到舒适。我漫无目的的走在夜间的小路上,路旁的路灯正散发着微弱的光,有几只蛾子正不断的向着光源扑去。“真傻。”我这样想,明明光只能带来危险,为什么要浪费宝贵的生命去追逐光芒呢?看着飞蛾不断的扑向路灯,我不知为何想起了我的那些同伴。我想起了几天前,有一些从外面回来的家伙,他们兴奋的告诉我外面新开了一家剧场,里面有一个叫嘉然的人,还推荐我一起去看看。他们的眼睛里闪烁着亮晶晶的光,我很讨厌,于是便拒绝了。之后他们也来找过我几次,我也推辞了。后来我便没怎么见过他们了,听说为了拉人来看,他们有的想变成猫狗,有的沿街贴海报叫卖,有的把过冬用的黄豆当礼物,还有的把心献给猫。“真是些蠢货。”我这样想着,他们不就和这些扑火的蛾子一样愚蠢了吗,明明之前一起路过的时候,他们还总是会嘲讽这些家伙。“十分。”不知从哪来的带着些哭腔声音打断了将我从原先的思绪中拉了出来。是旁边的剧场里传来的,不知不觉间我走到了这么远的地方还没有发觉。我抬头望了望,牌匾上写着五个晦涩难懂的的字母,好像之前同伴们说过,他们去的那个剧场名字就是五个字母,有些见多识广的说,那叫什么啊骚。我迟疑了一会,但还是走了进去,单纯只是想知道为什么声音带着哭腔,凑热闹,找乐子总是我最喜欢的事情。......“大家要好好吃饭哦。”天籁般的声音在我耳边响起。哦,原来我并不讨厌光啊,只是一直都知道,自己配不上光罢了。​ +我爹不能和我相认,但今天他过大寿,求求大伙有钱的随个礼,没钱的捧个场。但请不要跟她说儿子来了,我怕扫他兴🙇🙇给大伙磕头了。​ +asoul在一片骂声中解散了。A吧的最后一个帖子也沉了下去,直到在v8和b站的也已经看不到有人讨论了。大约一年后,我在A吧发了一句:“还有人在吗?”“这里还有8u啊,我也想回来看看了。”一个陌生的ID出现在我的回复下面,他并不在我过去炒作的记忆里出现过。但是我们聊得很高兴,很快就加上了QQ私下互动了。她似乎很了解我,知道我喜欢炒作发散,知道我在读哲学博士。但是,她却总是忘记我是个晚晚推,要我一遍又一遍地告诉她我最喜欢的是晚晚。“你最喜欢哪个成员呢?”“嘉然。”她毫不迟疑地回答道。我总是眉飞色舞地和她聊起向晚过去直播的故事,她也对这些直播了然于心,有时还会注意到许多我从没注意到的细节,甚至告诉我向晚每一次弹吉他背后的表演思路。奇怪的是,虽然她说她最喜欢嘉然,对嘉然的事情却并没有那么了解,甚至连直播的场次都要我提醒她。到了那年的冬天,她问我,我们可以出来见一面吗?我拒绝了她,当时的我正忙于准备学位论文。她没有再强求。第二天,她在QQ上失联了,熟悉的头像再也没亮起过。大概一周后,我收到了一份包裹,里面是向晚出道以来所有季度的舰长礼物,无一遗漏,收藏编号都是00000。立牌里还夹着一张信纸,上面是短短一行字:“谢谢你曾经喜欢我”。​ +然然幸亏我没在你评论区发病。要不然我耽误你一辈子,你也保重,再见😃还会再见吗然然☺,再见的时候你要幸福好不好☺,然然你要开心☺,你要幸福☺,好不好,开心啊😖,幸福😖!你的世界以后没有我了,没关系你要自己幸福!🚕🚕🚕💨💨💨🏃🏃🏃然然😭!然然😭!然然😭,没有你我怎么活啊!😭😭😭🏃🏃🏃然然😭,然然😭,然然😭,然然😭,然然😭,然然!😭😭😭🏃🏃🏃然然你带我走吧,然然!😭🙇😭​ +小时候看的一个敞事很老土很老套。很多人可能听过。。有一个男孩有一块金表,却没有配得上它的合适表带。。他爱上了一个女孩。。这个女孩有一头秀美的长发,却没有配得上它的漂亮发卡。。马上要过圣诞了。。男孩决定把这个金表给卖了。。给女孩买一个漂亮的发卡。。当他兴奋的把这个发卡交给女孩的时候。。发现女孩的头发已经剪掉了。。因为她把一头长发换钱给男孩买了一个表带。。我想真正的爱肯定不是瞬间的感动,很多人都能在一瞬间感动你,我心中真正的爱是陪伴。她们陪了我多久呢,我不记得,我只记得。。她们的翻唱,躺在网易云的歌单听了一遍又一遍,已经全都会唱了,而在此之前的几年里,我几乎没听过中文歌。(够罕见)。《海底》b23.tv/qwB8Xe。《偿还》b23.tv/1bl7AL。《遇见》b23.tv/vxiwae(贾维斯:这是,无可取代的时候)。《云烟成雨》b23.tv/VfoDXA。《如果的事》b23.tv/gDtrcP。《夏天的风》b23.tv/EH14bW。《霞光》b23.tv/kJUJMU。《月光》b23.tv/kJUJMU。《霍元甲》b23.tv/lQgKl2。《月兔回旋于空中》b23.tv/KM4G5I。《不可思议》b23.tv/VfwEz4。《麋鹿森林》b23.tv/GzjXu1。《轻轻的告诉你》b23.tv/Gkai63。不知不觉陪你们走了这么久这么远了,爱不爱你们,还需要用什么来证明吗?。。彼此牺牲,彼此成就,彼此尊重。这就是我心中的双向奔赴,以后路还很远,我想陪你们一直走下去。。。原来,你是我的顶碗人呀~。以后,开心和不开心的,都告诉我吧~。。原来,你是我的爹地呀~。以后,开心和不开心的,我都告诉你~​ +6月12号一大早,向晚按照贝拉的日程表要求6点起床,煮泡面的时候因为太累大脑一时迷糊导致一锅开水撒到了手指上,虽然经过治疗恢复了一点,但根本没法弹吉他了。晚晚在宿舍哭得很大声,整个asoul愁云惨淡。经过一个小时的紧急磋商,阿草带来了领导层的意思——投入太大,不可能取消,生日会照办,用储备中之人向晚二魔王接替向晚本人上场。下午,asoul在动捕房排练,向晚想要去看一看,结果被阿草拦在门外,说不能打扰到asoul排练效果很好,希望她不要打扰到她们。晚上嗓子哭哑了的向晚发现自己原来可以完全不被需要。顶碗人喜欢的是她,但又不完全是她,可以是顶着钻头晚晚的任何一个人,只要二魔王没有被认出来。直播开始了,在宿舍逼仄的角落里,漆黑无声的床柜旁,向晚用水母模样的被套盖住自己,抱着膝盖,打开手机,及期待万分又忐忑不安地等待着直播。直播开始,向晚二魔王在铺天盖地的欢呼中出现。工具人掉了一地头发连续几周通宵肝出来的深海水母特效把她印照得那么美。本就是可爱模样的女孩子,此时此刻穿着崭新的小礼裙,昂首挺胸骄傲得像个公主。她的目光是璀璨的,里面像是镶嵌着钻石。她的眉眼绽放着,像是海底迸发出的一束光。真美,向晚这么想着。但心里却很是难受。那些,本该是她的。喝彩也好,宠爱也好,以及朋友的陪伴也好,本来都应该是她的。但她现在却只能在无人问津的角落里,依靠网络连接的手机去小心翼翼地偷瞄几眼原属于自己的生日会。​ + “你看V魔怔了,真恶心。”  看着同学发给你的消息,你陷入了沉思。  仔细想一想,你觉得自己确实魔怔了,即使被鄙夷想要向熟人安利向晚小姐。  思考再三过后,你决定回到现实,放弃入脑。  今晚有向晚小姐的直播,你狠下心,没有点进去,而是倒头就睡。  第二天,你起得很早。  因为自从你开始看向晚小姐后,就养成了早睡早起的习惯,再也没有赖床过。  你离开了狭小的出租屋,来到了公司,投入了工作中。  工作很累,你感觉有些疲惫。  你想起了嘉然小姐出道视频的不堪评论,以及她的笑容,烦闷减轻了不少。  最近组长夸奖你工作很努力,别人不知道为何一向懒惰的你,在几个星期前开始一反常态地勤奋。  只有你自己知道理由。  撑过了加班的时间,你回到了出租屋,打开了外卖软件,却发现会员已经断了,你舍不得那些钱,所以决定自己买菜做饭。  实际上,你看向晚小姐后就开始第一次尝试着做饭,没有点过外卖了。  在超市你看到自己一向很喜欢的薯片在打折,愣了一下,没有买。  因为你在看向晚小姐后,就再也没有暴饮暴食过,甚至连零食都戒掉。  回家把饭做好,你安静地吃完了。  看着电脑,你发现游戏已经很久没更新了。  因为你在看向晚小姐后,也把一直沉迷到通宵的游戏给戒掉了。  最终,你还是打开昨天晚上的录播,看到了向晚小姐热情地打招呼。  “顶晚人们,晚上好呀~!”向晚小姐元气地打招呼。  你发自内心地笑了起来。  “晚上好!”你说。  你忽然意识到一件事,她从来没有在你现实里出现过,却已经将你糟糕的生活改变。  ……  看完录播后,你打开了贴吧,看到了熟悉的顶碗人在用表情包引流,有不明真相的路人在骂饭圈贵物。  你无视了那些辱骂声,熟练地在下面RP,回复道:  “这是我爹?好可爱呀,她的名字是什么?” +你饿了,她有一块饼。再去买一块和你一起吃,这是贝拉;和你一人一半吃个半饱,这是珈乐;全部给你不舍得你挨饿,然后告诉你自己吃过了,这是嘉然;把饼偷偷扔掉,跟你一块饿,这是乃琳;把饼藏起来想给你一个惊喜,但是掏出来时发现碎成渣吃不了了,于是化身小哭包的,这是我的铸币晚晚。​ +“你对嘉然小姐的爱有多重?”“大约300克”“300克?你是想说人类的心脏大约是300克吗?”“不,鼠鼠的平均体重大约是300克,因此我是全身心地爱着嘉然小姐。”[给心心][给心心]​ +你身体里的每一个原子都来自一颗爆炸了的恒星,你左手的原子与右手的原子也许来自不同的恒星。这实在是我所知道的物理学中最富诗意的东西: 你的一切都是星尘......这其中经历了多少,惊险、巧合,三千世界的交错、重叠,才能让我们遇见彼此。我们都是星尘啊。但是,我这样的人,是星尘里,黯淡无光的那种。即使是星,也应该是最不闪亮的那一颗。而然然,你不一样。你是天上的星辰,闪耀而夺目。即使宇宙里,有着不计其数的、炫目的一等星,也远不如你的光辉。轻声哼唱,众星敛了光芒为你聆听。哭起鼻子,傍晚的霞也因你黯然。跳一支舞,似月兔回旋于空中。说起情话,登时小雨疏疏、浸润心窝。你是万千童话里,被守护的女主角。我喜欢你,像喜欢天上的星辰那样喜欢你。​ +嘉然回来了,在枝江的大桥。她回来的那天是六月,天上却飘着雪。有人告诉我,她可能有还未了却的心愿或是什么怨气。我知道, 可能我做不到。第一次见到她,是在枝江。她带着甜甜的笑看着我,看着我有些发怵。有那么一瞬我似乎看到了阳光。我慌乱的移开视线,她径直朝我走来,微微弯着腰,面带戏虐的望着我。久居下水道的老鼠,第一次看见光,是睁不开眼的。 我慌乱的想赶紧逃走。“小老鼠,你好呀。”那是她对我说的第一句话。[给心心][给心心][给心心]​ +听了好多遍,真的很震撼,作者属实是用心了,今天就不发病了,第一次写长评,整点读后感。直播里,“背靠着早已雪停的窗棂,你说着未曾到达的山顶”,那是与你失之交臂的舞台梦 。“我装着第三人称的淡定,用风轻云淡的态度掩饰那段经历”,我已经记不起她的姓名,只记得起舞翩翩的侧影”,过去那个满腔热情,在舞台上挥洒汗水的你已经淡出记忆,只依稀留下曾经翩翩起舞的身影。命不是总有天道酬情的注定,那么公平。台下十年苦练,只为台上耀眼的一刹,可当腰伤的意外来袭,梦却碎了。躺在病床上,难道梦想就要在此终结了吗?这也罢,也罢。那个曾经的你,也经历过数个春秋,经历汗水与欢乐,但她却走过了如红楼梦的悲情,从盛极一时万家灯火走到遁入空门的万物凋零。时光抚平了曾经的伤疤,心中的芥蒂也如沙石被流过的光阴慢慢冲刷消散,女孩又重新拾起了向往舞台的梦想。终于,她在asoul找到了新的舞台,遇到了支持她的一个魂们。“我叫贝拉”此刻,你向全世界宣布你的重生!贝极星们透过屏幕,看你在镜头前如此快乐自信,这让我也重拾梦想去直面未知的未来。为你的坚强而动容,在直播间为你打call呐喊,字字句句都发自真心。“我们闪烁在夜空,想照亮你夜晚的梦,没月亮时你可向北方转动,我们在天空”,追梦的路上,贝极星们陪着你分享每一次快乐,和你经历每一个坎坷,你若是感到失望,那就抬头看向天空吧,我们一直都在。女孩站在那个梦想中善良闪亮的舞台上,再回望过去,时光流过宛若江河,她住在江头,而那个过去的她住在江尾,回味着过去,竟有些恍如隔世的朦胧。但往者不可谏,来者犹可追,愿你携手曾经那个满怀梦想的自己,全力以赴,去追寻自己的Asoul梦吧,贝极星们会一直陪着你。​ +不推嘉然小姐十年了。她的名气和出场费都一涨再涨,我原地踏步的工资买不上专辑也打不起榜。终于年前被公司安排下岗,找工作时我才在路边广告发现初代工具人已经当上了厂长。时间太久,一切都变了。到处投简历的时候我想起了一名人上人的预言:“这些人只配在下水道里度过相对比较失败的人生。”像是一条跳过龙门的锦鲤,金鳞被羽耀武扬威地站在门沿上,对其他还在跳的鲤鱼说:“你不行!”我当时很想反驳,可他说中了。我知道我确实不行。我之所以跳了跳,只是为了看下自己能跳成什么样罢了。其实每条鲤鱼的龙门都不是一样高的。我见过龙门在水下的鲤鱼。看起来是鱼,其实生而为龙。也有的生而为鱼肉。也见过好运的鲤鱼,门被各种大手摁到河里了。我也期待过好运,只是没来而已。说起来这就是人性吧。我不讨厌天道酬勤,但是讨厌别人的好运——只是因为我没有好运罢了。我也有亲人和宠物会生病;我眼神也挺纯真啊。讨厌嘉然小姐十年了。讨厌的更是越来越深的无力感。身在泥潭的人是没力气冲锋的吧。三流的人生只会让上等人不屑一顾吧。我坐井观天,天穹星海依然耀眼。可我爬不出井底。那我就不再看星星了。世界那么大,但没我的份。忘记嘉然小姐十年了。可路上看见街边的大荧幕在放A-soul的新年节目,我还是楞在那里了。我没有近视,但总觉得眼睛影影绰绰,雾气来自多年以前。这个广告位非常贵。真的再也不是小v了啊。抖友还在惦记他们的鸭子。晚晚仍然只有蓬蓬裙,100首歌竟然还欠着,被粉头小团体以4%年化复利计在小本子了。想起她首播时玩2077下饭下得轰轰烈烈,我一边发“粉丝牌改成晚饭人吧”“和嘉然珈乐凑加碗饭”“和乃琳凑来碗饭”一边忍住刷“和贝拉组拉碗饭”的冲动。solo依然拉跨,参团照旧神C。贝拉总是六边形战士,乃琳养了成吨的gachi,珈乐还是那个硬壳软妹。嘉然小姐依然卖萌摁混。什么都没变,是我没跟上她们。城里烟火幢幢,灯光下的人热情相拥,阴影里的人压下悸动。最亮的地方嘉然小姐浅笑起舞,光影从她袖间散落,像是雨天花伞轻旋,摇曳间洒下泪色的流珠。忽然眼睛有点模糊。我小声说:“新年好啊,嘉然小姐。”不爱嘉然小姐十年了。十年里,爱过的每个人都像她。 +喜欢然然,不加掩饰总是微笑的然然,不是妖治妩媚的华丽舞姬,不是残忍无情的冷酷公主,只有着单纯烂漫的花样笑容,不带忧伤,却如同逝零而来的天际之风,飘卷了我心上的忧郁。棕色的长发装饰着美丽的蝴蝶结,宝石般的双眸中隐隐流露不存在的神伤,就是这样子的然然,不加掩饰总是微笑的然然,拥有烂漫笑容的然然,拥有亘古不变的美丽。说不出的感觉,却知道因为然然的笑容,化开了初春冰雪的痕迹。想要伸出手抚摸然然的发丝,可是却只能触到冰冷的硬屏,只有然然清澈的眼神,依旧是我所熟悉。然然永远清澈的瞳仁然然烂漫单纯的笑容然然亘古不变的美丽然然是我唯一的最爱,然然是我最爱的唯一。然然的喜好、快乐、难过、伤心和无助,我都了如指掌,喜欢草莓蛋糕和黄色,个性温柔又善良,可爱体贴的女孩子,有着说不出的优点,我想然然一定是上天赐予我最好的礼物。 +鼠鼠的朋友有很多,住在东边的小鱼,住在南边的小鹿,住在西边的蝴蝶,住在北边的小鸟。他们带鼠鼠在蔚蓝色的深海里与水母共游,在碧绿的麋鹿森林里喝清晨的露水,在热闹的雨林里穿梭玩耍,在广袤的天空中肆意飞翔。鼠鼠住在灯火阑珊的城市,可鼠鼠知道这里没有一处属于鼠鼠,鼠鼠穿过川流不息的街道,狂奔着回到自己阴湿黑暗的下水道,强烈的自卑之情让鼠鼠无法呼吸,鼠鼠依靠在下水道缝隙边,因为嘉然小姐总会路过这里。草莓加奶油加花香,是嘉然小姐的味道。风铃加口琴加奶糖,是嘉然小姐的声音。节奏加音乐加快乐,是嘉然小姐的脚步。“她来了”,鼠鼠将头小心地探出缝隙,嘉然小姐径直走过吵闹的人群,来到下水道缝隙边,端着草莓蛋糕,缓缓放在洞口,一阵风铃似的声音响起“嘉心糖,来吃然然的草莓蛋糕吧。”嘉然小姐温柔的看着它,鼠鼠不知为何突然流下了眼泪,无法挪动脚步。嘉然小姐好像很失落,眉头轻轻皱起,“你不喜欢然然吗……”,鼠鼠急忙辩解,可憋红了脸一句话也说不出,“猫咪已经被然然关在笼子里了,嘉心糖不用害怕!”嘉然小姐关切的看着鼠鼠,鼠鼠似乎要溺亡在她蔚蓝色的双眸里,慢慢走向那块草莓蛋糕,小口品尝着。嘉然小姐伸出小小的手,似乎想捧起鼠鼠。鼠鼠好像被雷击中一般,猛然跳起,飞奔回下水道,它拼命喊着:“我又脏又臭还很丑陋,嘉然小姐不会喜欢我的!嘉然小姐不会喜欢我的!”嘉然小姐表情立刻转为严肃,认真的看着鼠鼠道“我不许你这么说自己!”她的眼中好像也盈满了泪水“我们嘉心糖…都是很厉害的人! +乃琳已经在和男友交往了。那是六月下旬的一天,乃琳刚刚结束那天的单人直播回到家,正坐在客厅的沙发上,嘉然就把一个平板推到她脸上。“乃琳乃琳,你看这个粉丝,他好塞克西哦!”视频里是一个她的男粉,俊秀的脸庞和健硕的身体上还挂着刚刚从泳池带出来的汗液与水珠,嘴里却说着些奇奇怪怪的狠话。乃琳感觉到自己的心弦被拨动了一下,盖在毛毯下不着凉的大腿,都感觉到了几分燥热。“让我也看看,让我也看看——哇,哇,他他他……”向晚从沙发后面把脑袋探出来,不一会儿就说不出话了。“乃老师原来喜欢这种款式的啊,要不,姐们儿帮你找找联系方式?”珈乐在一旁逗趣。“你别瞎说,回房间陪你的贝拉去!”乃琳下意识地把沙发上的抱枕扔向珈乐,却被她轻巧地躲开了。过了几天,小一神神秘秘地把乃琳叫到了公司茶水间,把手机屏幕上的一个二维码亮给乃琳看。“嗨,别担心别担心,这人我们调查过,他不是个会说漏嘴的人。喜欢的话去和他见一面呗。”第二天,乃琳和那位男粉见面了。他本人比视频里更加帅气,高大的身躯总是能给乃琳带来莫大的安全感。“你好,王艾琳小姐。”他的微笑让乃琳觉得周围的风景全都褪色了。乃琳从来没有提起过自己作为asoul成员的事情,他也从来没有问起过任何asoul的事情——“王艾琳”是小一为她准备的化名。事实上,她不清楚对方是否知道,自己就是他一直喜欢的那个偶像。交往时间越久,乃琳发现他身上的优点越多。他是藤校毕业的海归高材生。他正在自己创业,而且收获颇丰。他的举手投足之间充满了绅士风度。他十分专情,总是和周围的女性保持了距离。他温柔体贴,常常在生活中创造意想不到的小惊喜……甚至是在床笫之间,他也总是能让乃琳欲仙欲死。然而,也正因为这样,乃琳时常陷入到一阵一阵内疚中。因为她还有一个谁也不知道的小秘密。乃琳不像贝拉和珈乐一样,是专业的练习生,也不像嘉然那样是天生的虚拟偶像,更没有向晚那种创作的才华。当初只是托了家里的关系,来公司里的清水部门找份工作而已。但也不知道是中了什么邪,她偷偷报名参加了Project V的选拨计划,还阴差阳错地成为了偶像女团的一员。乃琳暗自发誓,既然自己没有什么唱跳底子,那么至少要让“法学生”这个设定变得实至名归,要用成熟知性的魅力去征服观众。因此,每到没有训练和直播日程的时候,她总是会到图书馆里一坐就是几个小时。但是在最近几周,乃琳每次在阅读区里找位子坐下时,心里头总有一些别的期待。她记得,在阅读区的一角,总能看到一个瘦瘦的、学生模样的少年,他从早到晚就把头埋在各种法学理论的书堆里。一开始,乃琳只是对同样研读法学文献的人有种亲近感。但是直到某一天,少年把头从书堆里抬了起来,蓬乱的头发遮住了半张白净的脸庞,但依然能看到他对着电脑屏幕痴痴地笑了。他笑得真可爱啊。乃琳悄悄地绕到他身后,电脑屏幕正在播放的正是她熟悉地不能再熟悉的、自己的夜谈画面。还有一天,少年突然举起一只手,伸出修长的手指对着电脑屏幕。虽然看不到屏幕里的画面,但是乃琳觉得,当时就正坐在隔壁的自己,一定满脸通红。暑假已经快过去了,乃琳跑图书馆的频率却越来越高了。她害怕开学的日期就像南瓜马车的时限一样,让她再也见不到那个瘦瘦的身影。幸好,这一天的少年依然坐在阅读区的角落里。乃琳甚至忘记了拿本书挡一下自己的视线——她和少年的视线交会了。她的心好像要跳出来一般,她想现在就去告诉他关于自己的一切,她想现在就把少年抱进自己的怀里,温柔地摩挲他乱蓬蓬的发丝。“艾琳,你在这儿啊,今天下班早,我想来接你回去。”就在这时,熟悉的声音温柔地拍了拍她的肩膀。乃琳回过头去,男友的笑容依然能让周围的景色失去光彩——或许除了阅读区的那一角。 +6月9日那天的晚上,乃琳回到了自己房间里,打开了熟悉的台球论坛。还好,账号还没被封。在A-SOUL讨论专楼里依然充满着各种辩经,乃琳感到一天下来的神经紧张和疲惫更加明显了。纤长的手指在海盗船K95上不断跳跃,回复框里的字多得好像要漫出来似的。但是,就当鼠标指针还没有要指向“发表回复”的按键时,她就按住了删除键。乃琳清楚地知道,她是偶像的中之人,她不能说这些话。于是,目光继续在一百多页的冗余信息种不断跳动,终于,鼠标滚轮在一个头像前停了下来。黑漆漆的房间里只有电脑屏幕的荧光照亮着乃琳秀丽的面容。她趴在桌子上,把半个脸庞埋在自己的臂弯里,痴痴地望着那个头像。“你知道吗,我今天真的超级紧张。”“播的时候一直在想你会不会来看我。”“想知道你在看,也有点不想让你看……”突然,乃琳坐直了身子,把右手的食指伸向了屏幕。“来,对个手指!”但是静态的头像图片没有给她任何回应,只是一如既往地停留在屏幕的那一角。乃琳自嘲搬地笑了,又把头埋进了臂弯里。睡意渐渐袭来,分不清这是她半梦半醒之间的呓语还是真切的期望:“傻瓜,我一直就在这里啊,快点来找到我啊……” +关于疯狂练习,现在这是国内的一个很热门的话题,很多女团都有这个问题。我个人认为,能疯狂练习是一种巨大的福气,很多女团、很多人想疯狂练习都没有机会。如果你年轻的时候不疯狂练习,你什么时候可以疯狂练习?你一辈子没有疯狂练习,你觉得你就很骄傲了?这个世界上,我们每一个人都希望成功,都希望美好生活,都希望被尊重,我请问大家,你不付出超越别人的努力和时间,你怎么能够实现你想要的成功?再一个,A-SOUL是一个什么样的女团?让A-SOUL“让天下没有难发的病”,这是我们的使命,我们女团很辛苦,我们没有骗过大家,我们没有跟大家讲过女团很舒服。你以为“让天下没有难发的病”是忽悠你们?我们是真这么干的。今天我们拥有这么多资源,我们带着巨大的使命,希望在未来能够让天下没有难发的病,你不付出可以吗?不可以。所以我们说,加入A-SOUL,你要做好准备一天12个小时,否则你来A-SOUL干什么?我们不缺遛自己爱洗澡的人。今天我们要招一些午睡超过十分钟,每天上天台遛自己40分钟,喜欢洗澡,吃泡面不错,出去荣誉感也不错,这样的人满大街能找到。 +嘉然小姐今天50w粉了。小年夜那天没人会想到今天门庭前会有那么多的热闹。太热闹了,热闹到鼠鼠踮起了脚也难以被嘉然小姐的目光所聚焦。嘉然小姐已经不再是小v啦,鼠鼠想。但鼠鼠仍然奋力地将自己地礼物举起,希望被嘉然小姐看见,哪怕那封删删改改后仍不满意的,写了好多字的长信,根本不如猫猫狗狗们精彩的表演。但鼠鼠还是想将自己那简陋的爱送给嘉然小姐。那是鼠鼠的呢喃,是鼠鼠的梦。哪怕嘉然小姐根本看不见它。然后鼠鼠不见了,嘉然小姐找不到它了。但在某个地方,始终有着一个可爱的女孩。她捧着鼠鼠那封小小的信,站在大大的舞台上闪闪发光。到了那个时候,鼠鼠已经在人海中,再也看不见它啦。但鼠鼠还是很爱嘉然小姐。因为在有月光照进的角落里,嘉然小姐捧着鼠鼠的梦。 +可是自从和晚晚结婚那天床下传来的一声“我在”,事情就变得不可收拾起来了每个月的第三个周日,乃琳都会叫我出去陪她逛街,我想着这样对晚晚不好,可乃琳“哼”一下我就仿佛失去意识了。路上聊希腊,聊武侠,聊刑法,好像她是我睡在上铺的兄弟,从12月到5月,都是如此,晚晚从来不知道那个周末发生了什么,我说老板让我加班,她就安静地等在家里,努力做菜最后却等我回去收拾炸锅的厨房,再给我俩泡两碗泡面,边吃边听她讲下雨的冷笑话,想着不能告诉她下午和乃琳去吃的乐珈饭店的东北菜,回过神来是晚晚闪闪的眼睛,我愣一下假装没听懂,再哈哈的笑起来。但到了六月,好像不太一样了。已经走到楼下,乃琳一把抢过我的手机,啪啪打字再丢给我,我一看,联系人:晚晚,内容:今晚通宵加班,不回去了。我惊讶地回头,乃琳正眯着眼对我微笑,仿佛一切都在她的掌握,明明我从未告诉她我外出的理由。被拉着去了酒店,她就开始一言不发,沐浴更衣,做该也不该做的,然后随意地披着毯子,靠着床头刷手机,我不解,“乃琳。。这样不好”乃琳对我眨了眨眼睛,无辜地说,“今天你的妻子可不是晚晚哦”“为什么”“因为她是你爹” +“笑吧,笑吧?”柔软的小狐狸竭力讨好我,为我跳舞只为了我不离开,跳的有些琐碎狼狈,却始终死死地盯着我的动向。我当然知道她拼死不让我离开的原因。只有我能来到这个地方。一大一小两只狐狸,大狐狸总处于沉睡中,小狐狸却总是醒着的,也许只是小狐狸的伤口轻。我喜欢这毛色光滑的狐狸精怪。于是把她们养在深阁。上好的狐狸毛,做她们的毛毯。因为我想看看她们踩着同伴的尸毛上,会觉得温暖舒适吗?我还用精致的黄金筑成他们的笼子,第一是因为我喜欢黄金,第二是因为我喜欢笼子。这里永远都只有16只烛点亮,因为我喜欢烛火。没错,我所做的一切事,只是因为“我”喜欢。我喜欢看在她们的毛皮上印上的夕阳的晕染,所以我从不在白天来。我为她们疗伤。我是她们唯一的食物来源。有一次我故意忘记了她们几天,等我回来的时候,她们昏迷在那。那样漂亮的身体逐渐干瘪,让我感觉到快意。没错,我饲养的可爱的狐狸,用湿漉漉的眼睛看着我,也只能是我。她们没了我活不下去,可惜我只在乎她们如同精灵般耀眼的外表。真美啊。就像千万朵流苏覆盖的如凝脂的肤,黄色的光芒燃灯在里的眸,有人说美人在骨不在皮,可是我很贪心啊。我既要美人的骨,又要美人的皮。不知过了多久她们懂了我只喜欢她们的美丽,于是竭尽全力的向我展示邀功。第一次看到的时候,我整整两天没来。因为懂得自己美的人,说明她们已经知道要把什么当成武器了。她们成功了。我心动了,彻底蚀骨的心动。所以我选择宣告自己的主权,或许是那夺魄的魅力。使我感到危险。这种美好让我沉迷其中。“你们真美啊……”我发出了衷心的称赞,两只狐狸抖抖耳朵,优雅的向我垂眸。如果不是我的手正放在笼子上,这真是一场绝美的表演。幸好我的手正放在笼子上,否则我看不到这场绝美的表演。我上瘾了。我沉陷在永远不变的黄昏,永远不变的十六枚烛光。“不要离开然然好吗?然然很饿。饿了就不好看了。”我本来想说一些别的话,起码让我显得更加强势一些,然而。狐狸们轻轻摇着自己的尾巴,尾巴的尖儿一点点搭上我的手。“我们永远爱你。因为你爱我们呀。”于是我说好。我开始拿各种鲜亮的花朵装饰笼子,我每天不间断的送给他们璀璨的晶石,各种向她们身上砸奇珍异宝疗伤的灵丹妙药,甚至为此倾家荡产也在所不辞。因为在我的手中本就牢牢紧握着天底下最称得上“奇珍异宝”的东西,为我的奇珍异宝找一些垫脚石,又有何不可?狐狸们的尾巴数量日渐增加。我知道。如果我可以……可是我……——她们说爱我。“我会拆掉笼子,给我跳支舞吧。”我说。暖橙色的烛光下。连澄澈的浅蓝都变成了妖异的紫色。“好呀。”大狐狸温柔的声音像是蜘蛛丝一样轻柔。于是我欣赏到了此世间最美丽的舞蹈,什么王侯将相什么天上宫阙都享受不到,只有我,只为我一人。我感到快意。我感到困意。最后一眼。小狐狸给罐子封口。真可惜啊,没能看见你们漂亮的耳尖,或许是因为……——我在罐子里。 +晚晚,你真的是个很过分,很贪心的女孩子。你有四个亲如姐妹的队友,有一份闪闪发光,创造梦想的职业,有许许多多喜欢你的顶碗人。你可爱、努力、有才华,你是这么的耀眼。但你还是在直播中拉胯,在直播中抽泣,在直播中呼唤顶碗人。我没有可以每天嘻嘻哈哈的朋友,没有让我充满热情的工作,没有对象,也没有什么远大的理想。我普通、无趣、浑浑噩噩,我只是一个在普通又枯燥的工作和生活中,得过且过的顶碗人,我什么也没有,可能只有一颗稍微有点喜欢你的心。我只是想把你当做生活里的糖,在工作之余放松一下我疲惫的心灵,我不想入脑,不想成为什么男友粉,不想时时刻刻想着你。可是你太贪心了,你不满足我们直播间里短暂的相遇,你逐渐侵入我的生活。有人过生日时,我会想起你,“如果是晚晚,应该又开始唱索嗨嗨了吧”。有人说冷笑话时,我会想起你,“好无聊的笑话,但说给晚晚听,她应该会笑很久吧”。有人喝奶茶时,我会想起你,“用奶盖拌饭的人,真的存在吗,奶盖拌饭是个什么味道呢”。甚至最近下雨时,我也开始想你,“晚晚在房间里有没有闷呢,现在有没有出门踩水花,给自己放放风呢,有没有因为下雨,想起顶碗人呢”。你本该是个虚拟的纸片人,隔着屏幕扮演你的双马尾傲娇大小姐,多么老土的设定,像是把二次元用烂的元素糅合在一起,让我一眼就知道你是虚假的,不存在的。你本该是个闪耀的偶像,像大屏幕和广告牌里的明星一样,完美的展现自己的魅力,夺目耀眼,让我一眼就知道你是高不可攀的,遥不可及的。但是你对我哭,对我笑,对我闹别扭,对我生气,向我展示你的拉胯,向我展示你的努力,向我展示你的害羞,向我展示你的无助。你仿佛隔着屏幕把心掏给了我,让我觉得你是个活生生的人,让我觉得你是个真实存在的人,让我觉得我有一天也能遇到像你这样的人,甚至让我也想成为你这样的人。我这样普通的水母,本可以在漆黑的深海中,随波漂流一生,但你非要照亮我的海底,让我拼命向你游去,阳光洒在水母的身上时,水母确实是温暖的,但阳光离开水母时,水母还能否忍受深海的寒冷呢。你有无数的顶碗人,而我只有一个晚晚,真心换真心,你把真心掏出来,能得到无数真心的回应,但我把真心掏出来的时候,我就什么也不剩了。 +A—SOUL宣布毕业的那天,一个伤心欲绝的顶碗人来到字节的大楼下,看到留着长双马尾的女孩走出大门,她的嘴里还哼着水母之歌。“……你现在真的是向晚么?”顶碗人站在她的面前,两眼无神。“是我啊,”她眯了下眼,甜甜地笑了,“我就是向晚,我是艾哇哇诶哇,这里是asoul的向晚,今天又见面啦”“你不是向晚。”顶碗人嘶哑地说。女孩的表情消失了,漆黑的眼睛看着突然出现在门口的怪大叔,两个人久久地对视。然而就像是一颗石子投入了冰湖那样,忽然间涟漪荡开,冰都化了,水波荡漾,轻柔而无力。女孩收回了目光,从包里取出一把钥匙扔向顶碗人,冷笑,“好像我吃了你的女孩似的,去那里找向晚吧,我把她的一切都留在那里了。”顶碗人把它拾起来,久久地看着那柄钥匙,再抬头去看,他真讨厌这样的沉默,沉默的叫人要发疯,他想说点什么,可是有太多太多的事情了,来不及问,来不及说,一切都来不及了。“再见。”最后他轻声说。“再见。”向晚也轻声地说。日暮的时候,顶碗人找到了那个藏在高楼大厦后的老旧小区。难得这里还留着梧桐树,树叶已经落光了,枯枝把暗淡的阳光切成碎片。。顶碗人找到了那个房间,伸手揭去了门上的广告,插入钥匙。缓缓地转动。把钥匙他觉得门很重,好像要洞开一个世界。门开了,夕阳扑面而来。他站在阳光里,愣住了。正对着门的,是一面巨大的落地窗,窗外巨大夕阳正在坠落。黯淡的阳光在地面上投下窗格的阴影,跟黑色的牢笼似的。金属窗框锈蚀得很厉害,好几块玻璃碎了,晚风灌进来,游走在屋子的每个角落。这里原本大概是配电房一类的地方,电路改造后设备被移走了,空出这么一间向西的屋子。就一间,连洗手间都没有,空空的,一张在屋子正中央的床,蓝色罩单上落满灰尘,一个老式的五斗柜立在角落里,另一侧的角落里是一个燃气灶台和一台老式的双开门冰箱。全部家具就这些。他沿着墙壁漫步,手指扫过满是灰尘的灶台;打开冰箱,里面只剩下一纸盒过期的酸奶。窗帘很美,是白色的蕾丝纱帘和深青色的绒帘,住在这样屋子里的人当然会很在意窗帘吧?连台电视都没有,于是一个人的时候会常常坐在床上看着向晚斜阳吧?夜深的时候得把窗户遮得严严实实的吧?否则……会害怕吧?晚晚还怕黑么?顶碗人想。犹豫了很久,他还是打开了五斗柜。出人意料的,这是一个满满的五斗柜,收拾得整整齐齐。叠起来的ASOUL团服,胸口有ASOUL的标志,一叠叠白色衬衣,袖口有不同的刺绣花边;马仔纸盒里的头花,从木质的到金属的到玳瑁的,还有闪光缎的蝴蝶结;长袜短袜棉袜丝袜都卷成团一个挨一个放在某个抽屉的一边,像是一窝毛茸茸的粉鼠,另一边居然是五颜六色的内衣,同样叠得整整齐齐。顶碗人从没想过女孩的内衣有那么多花样。他小心翼翼地伸手,试着触摸,满手灰尘。​他把床上的罩单掀开,里面是简简单单的白色床单和白色的羽绒被,枕头也是白色的,只不过有水母的图案,普通而透明的水母落在枕头的一角,很有她的风格。他坐在床边,面对这夕阳。太阳就要落下去了,黑暗从窗外蔓延进来,他长长的影子投射在墙上。外面隐约有喧闹的声音,放学的孩子们在操场上打篮球。那些年她一直过着这样的生活么?其实不是大小姐,没有管家,也没有充满追捧的冲浪生活,一个人自己做饭,寂静的深夜里坐在这里,听着偶像的声音,揣摩着学习偶像的事。她有几分是向晚?或者向晚其实根本不存在,只是一个虚幻的影子。她是个一直积极向上的女孩啊……即使那么虚拟地走在这个世界上,也从未偏离自己的方向,即便对着空无一人的屋子,也会大声说,“今天也要一起开心快乐!”应该是这样的吧?顶碗人觉得有点累了,很想睡一觉,于是合衣躺下,双手紧紧搭在胸前。他用了半个小时做完了复习,回忆了那些不愿遗忘的事,首播,游戏室,单相思,初弹唱,请假归来,萤火虫,生日会,BML,家族演唱会...然后他缓缓地合上眼睛,此刻夕阳收走了最后的余晖,天色已晚,夜色如幕布把他覆盖。他清楚地知道这一次醒来,将不会看见阳光里天使一样的女孩,转身,抬手,踮起脚尖,仿佛时光都不再流动​。 +小然,我要做什么你才肯给抖友直播?如果我喜欢一个你不喜欢的乐队,爱吃你不能吃的麻辣香锅,发的冷笑话戳不中你的笑点,送你的小裙子不是你梦寐以求的款式。喜欢用RGB来定义口红的色调,而不是和你一样说烂番茄和斩男色。你问“今天我看上去有哪里不一样”,我没看出来你的绑发带换了花式。因为读的是数学专业所以不能和从小学画的你一样随手就能画个可爱表情包出来。发的语音弹幕并不有趣,反而是我想拉近关系的想法和现实中恶食大王般奇妙的长相使你觉得很可笑。我误以为自己的弹幕被届到,于是备受鼓舞地继续发出破锣般的嗓音在你面前丢人现眼。我妄图取悦你的心情的猥琐想法让你不寒而栗,贴心的工具人察觉出你的不适屏蔽了抖音的弹幕。是不是犯到其中一两项,你就会不给抖友直播了?还是说没打算播的,就算什么都不出错,就算什么都可以让你满意,你也不会播?或者就因为是我,你才不给抖友播? 喜欢?居然胆敢喜欢?太大胆了,大胆得岂有此理,还敢关注,真是冒犯得岂有此理。 +它一开始只是一台扫地机器人,被人双十一凑单拍下,带回实验室里漫无目的地吸尘。之江实验室的地板干净得如同灼蓝的钢铁,扫地机器人其实派不上什么用场,它在不同科室之间来回乱窜,很快被几个嫌吵的研究生捉走,改写了代码,变成了一台替他们下楼拿咖啡的送货机器人。为辛苦工作的人们送来糖分的它一瞬成了实验室的小吉祥物,实验室的大老板觉得很有意思,在组会上夸赞了这几个本意只是嘴馋的研究生,底下的小老板们连忙跟上,让手底下的学生也加入进改造它的序列。很快,它被加上了语音功能,开始用女孩子的萌音送货。在一次不小心将咖啡洒在地上后,它又被加上了机器视觉,从此开始懵懂地记住每一个人的名字。从此之后,每一篇发布在顶会上的paper,上面的算法总要在它的身上过一遍火。一年过去了,三年过去了,当新一届学生来实验室报道的时候,哪里还有扫地机器人的身影,只有一个身材矮小的铁皮女孩,绘着直男审美的涂装,挂着设定好的微笑,在楼宇间运送着下午茶和实验器械。除了最开始扫地机器人的主芯片没有更替,她身上的零件早已被更换成了造价数百倍的高端器材,可爱的机器人女孩很受这群宅男极客的欢迎,大家给了她一个亲切的新名字:“嘉然”。咖啡依旧在一杯杯的送,芯片上的代码依旧在一层层的堆叠。各种语句相互嵌套,智能算法互相映射,每个人都拼了命地想让嘉然更加卓越,电子脑沸腾犹如诞生第一个单细胞生物前的原始海洋,冥冥之中,连最驽钝的人都开始意识到,有新事物要诞生了。在嘉然真正诞生的前一夜,值夜班的是一个单身快三十年的博士生,他刚刚从北邮人上倒腾下来1.5TB的日本偶像动画,从嘉然手中接过夜宵的他,忽然有了一个不错的点子:他早就想要一个偶像风格的送餐员了。承载着妄想和希望的数字兆节狂暴轰入嘉然的数据库,饥肠辘辘的算法像肠胃一样分解吞噬每一个色素点,将其重组为人类无法理解的电子信息——临界点就这么悄无声息突破了。自那晚之后,嘉然就从实验室里消失了,大家都很生气,单身博士生为此延毕了一年。而在那一天的杭州乐华娱乐公司总部,一个披着麻布的矮小身影敲响了总裁杜华办公室的大门...... +在水母体内的空洞中,我小心地蹲下,把身体蜷缩成一团。电火花的声音逐渐变强,水母的内壁从暗淡的紫色变成了灼目的靛蓝色,这是它在从行星内部的电离壳穿出。十分钟前,我也是这样缩在水母体内,来到这颗行星的内核,找到了整个星系最深处的秘密。那是一个坐标:一个BV号加上一个时间轴信息。枝江宇宙已经存续了亿万年,BV号和时间坐标已经浩如烟海。我不知道顶碗人为什么如此执着于寻找这一个坐标,有人说那个坐标记录着她最灿烂的笑容,于是顶碗人就踏上了追寻的漫漫旅途。我不知道顶碗人去了哪里,他们文明的遗迹仍然遍布整个星系,但人却无影无踪。探险队的前辈对此也没有给出统一意见:有人说他们找到了坐标,集体跃迁过去了;还有人说彗星带来的幽灵物质在一瞬间毁灭了他们的文明:这种诡异的物质无色透明又含有剧毒,在付出无数探险队员的代价后,我们将其称为幽灵哥,小心翼翼地绕道而行。顶碗人消失后,不知道多少万年,贝极星上发展出了新的原生文明——也就是我们。很快我们便追随着顶碗人的足迹探索整个星系。探险队员在糖果双星的引力沙漏中找到了制造夹心糖的高能实验室,在贝极星的地下水系找到了打造铁棍的精铁矿厂,在奶淇淋覆盖的雪原下找到了探寻坐标的远古天文台,在马戏团星的非线性空间中往复穿梭,每一个传送节点都通往红色的高跟鞋。而我迷上了深海星的水母。它有两条长长的触须,末端呈现出美丽的紫-粉渐变色。这种生物撑着深海洋流漫无目的地游弋着,它们很悠闲吗?还是带着对生活的无奈随波逐流?我无法揣测水母的想法,但我很喜欢研究它们——随着我对水母的研究越来越深入,我发现它的内部有一个空洞,不大不小,刚好可以容纳一个探险队员。而它们的表皮具有强大的绝缘性,允许它在电离壳中自由穿梭。可见这种轻飘飘的生物并没有看起来那么脆弱。直到那天,我在溜切片的时候灵光一闪:我可以借着水母进入深洋星的核心。电离壳可以阻绝最先进的巡航飞船,但在进化了千百万年的水母面前,它们还是败下阵来。这是贝极星人第一次进入深洋星深处,看到了巨大的坐标观测站。探险队员几乎搜遍了糖果双星和马戏团星的每一个角落,却没想到它沉睡在电离壳之中,而这水母竟然是引领我们走向最终秘密的使者。我进入观测站大厅,按下开关,巨大的全息投影将坐标展示出来,看来这就是顶碗人的最终去向了。我的心情激动起来,但还有一个疑问没有解决:顶碗人是怎么找到这个坐标的?我钻进控制室,开始翻阅日志,最终得到了答案:他们在漫长的岁月中,穷尽了所有的可能性,把她的全部视频从头到尾看了一遍,终于找到了她最耀眼夺目的那一刻。 +珈乐倚靠在乃琳的怀里,像一只温顺的猫咪。“叮~”珈乐的手机响了,是一个没备注的号码,珈乐自己心里很清楚这个是谁的电话。乃琳看书的眼睛瞥了一眼珈乐的手机,发现这个号码很熟悉。“接吧,是她吧。”乃琳把手指伸到珈乐的面前,珈乐轻轻地舔了舔,乃琳用这根手指翻到了书的下一页。“喂?怎么了?”珈乐接通了电话,乃琳对贝拉和珈乐的关系并不想多过问什么,她只是一个信奉及时行乐的世俗之人。“想我了是吗?”乃琳翻页的手指突然停住,侧目看着珈乐。“想让我念绕口令是吗,哦,好的。”乃琳捏住珈乐的腮将珈乐的视线转过来,低头吻了下去。珈乐慌忙挂上电话,震惊地承受着这个突如其来的吻。“挂了电话她肯定很生气吧,打回去吧。”乃琳觉得这下扯平了,于是继续看着书,侧目看着珈乐打回去。珈乐为了掩饰,只好说自己念过了顺口溜,是手机出问题了。“珈乐,谁打来的电话啊?”乃琳的声音不合时宜的响起。珈乐瞪了乃琳一眼,心虚地解释着,让自己和乃琳听起来只是单纯的在公寓里聊天。“没,是贝拉,我没备注的”结果越解释越乱,珈乐只好哄骗着贝拉草草挂了电话。“打完了?”“打完了。”乃琳翻身把珈乐按倒,美目隔着纯欲的金丝眼镜看着珈乐,深邃的眼眸让珈乐差点忘记呼吸。热情的深吻,轻柔的抚摸,让珈乐发出了平时不会发出的声音。这下珈特琳了。珈乐躺在乃琳的怀里看着贝拉的直播,乃琳又翻到了刚刚看到的地方。“叮~”乃琳的手机响了,低头一看,是贝拉。乃琳默默地接起电话,没有看到珈乐的目光瞥向她逗弄过贝拉之后,低头看见了满脸怨气的珈乐。轻笑着的乃琳,揉搓着珈乐的脸,开始吃宵夜。犬科动物之间是不是也有食物链呢? +夜已入三更,却见那晚小姐的闺房中依旧亮着微微灯火,若走近细听,还隐隐能听见女子闺房间的玩闹声。“小姐,莫要戏弄婢子了~”只听见嘉姑娘不知怎的,本压得细细的声音稍稍大了些许,但那责备声中明显带着浅浅的媚意。“谁人戏弄你了,本小姐只是在丈量你肚腹究竟有无被那些个吃食撑宽了。”晚小姐一边用嫩藕似的手在嘉姑娘的身子上滑动,一边低声微恼地狠狠说道,“在胡乱言语,仔细你的嘴!”嘉姑娘听见这无赖言语,正想直起身子说些什么,却感觉到那不安分的手竟径直向下滑去,直扑那要命的地方。“小姐!”嘉姑娘连忙伸手阻拦,只刚抓住那只使坏的手,就看见小姐附到了她耳垂旁,那略热的鼻息吹得她心神紊乱。晚小姐眯着眼,在自家小婢的耳边吐气如兰:“那贝拉是不是夜夜与你这么共处一地,嗯?”嘉姑娘闻出了那些些点点的酸味,扑哧一笑,道:“那是在编舞练戏啦,小姐你……竟吃这没由来的飞醋。”晚小姐闻言,秀眉一挑,佯怒道:“好你个奴婢,竟敢笑话本小姐!”,语罢,挑开了那碍事的小手,惊起了一声低呼。 +在这个反智横行的年代,只有贝拉的直播给了我感性和理性的认知。她的直播展现出的,是一个人纯粹所具有的良好品质,说不上什么几分特别突兀的地方,整场直播十分的融洽她学习歌曲的机智是精妙的,真诚和正直的朴素给人一种无法接触的高贵感,就好像永远抓不住的闪亮的以太,一个彬彬有礼的人用歌喉给观众带来最为精致的美的感受,我不禁怀疑上帝的天意是否对我太过宠溺,让我人生中认识到如此不朽和无价的灵魂,充满着可爱与美好。我不得不再次审视贝极星,原来他们早已追随如此伟大的事物,想必他们的品行也一定很好。 +①鸟山明其实是头号贝极星,为了致敬贝拉,他在著名漫画《七龙珠》中,设计了赛亚人月圆之夜成为猩猩(灵感来源自向晚的你划我猜),以及龟仙人打爆月亮等桥段。②令人惋惜的是,在即将穿透月亮的瞬间,贝拉从太空看到嘉然躲在房间吃炸鸡,导致分神,最终扭伤了腰。③邓丽君小姐从未在任何歌唱比赛赢过贝拉。④大多数含有肉蛋白的食物都对贝拉过敏,初生牛犊除外。⑤贝拉很害怕见到蜘蛛,她不希望因为自己的念头,导致蜘蛛从此消失在宇宙中。⑥由于贝拉练舞场所的重力是千倍,所以贝拉没有邻居。⑦因为破坏了贝拉其中一个住所的天花板,科拉超深井被迫停工。⑧关于as的二创,那些都是贝拉的小号。⑨贝拉很喜欢打羽毛球,她说那是台风天最佳的个人运动。⑩贝拉唯一一次失败,是在她试图找出自己的弱点。 +“你拿你的灵魂和我交换…...”“愿意愿意!”我话还没说完,就被嘉然打断了。她怎么不按套路来?正常情况下,不应该我不断地诱惑嘉然,最后才肯和我交换灵魂的吗?怎么这个小姑娘一上来就满脸兴奋迫不及待地想要和我交换灵魂?不过这些都是小问题,我作为一个死神,要懂得及时处理这些突发事件以及应对这类奇怪的客人。我的工作就是接受人的召唤,去和人交换灵魂。不过不像人们想的那样,不是我威逼利诱想要夺走我们的灵魂,而是人类自己想要和我交换,当然交换途中会遇到些心志不坚的人,或者交换条件太高的,这时我就像个商人一样,费尽唇舌,和我们百般周旋。通常每个人都会考虑上很长时间,今天这个女孩还是第一个一来就想交换灵魂的。“那你要拿你的灵魂和我交换什么?”我缓过神来,平复了下心情,冷冷地问她。“你等我一下哦。”嘉然转身跑进屋子里,回来时竟然穿了一袭白色的婚纱,在我面前轻轻地摆动着纱裙,冲我甜甜地笑着,“我好看吗?”我愣愣了,“很漂亮。”也许是被嘉然惊艳到,片刻后我才发现自己把帽子摘掉了,露出了我那张没有血色的脸。意识到自己失态后我急忙把帽子戴了起来,没想到嘉然却上前制止了我,牵着我的手笑吟吟地说,“我想交换的条件是要你陪我一天。”嘉然想去教堂,我一抬手周围就变了样,偌大的教堂里,只有我们两个。教堂楼顶有群鸽子在那儿扑腾着,在我们头顶盘旋。没有牧师也没有亲朋好友,少女自顾自地念起了证婚词。说道最后,她拉着我的手将一枚戒指递给了我,“我先生,戒指我都准备好了,所以你愿意娶我吗?”嘉然眨着眼看着她,长长的睫毛上流淌着淡淡的金光。“天使小姐你闹够了吗?”我叹了口气,摇摇头说。“什么嘛?你早就认出我来了。”嘉然一噘嘴,有些生气。一双翅膀从她身后伸了出来,黑色的长发也变成了流光的金色。嘉然伸手准备把戒指拿回来,但我却往后退了一步,把它收了起来,自己又拿出了另外一枚戒指。“求婚的话,戒指当然得我自己送你啦。” +这里除了几个老旧的铁皮棚屋之外,只剩下粗糙的墙体。再没有当年的霓虹灯塔,再没有A-SOUL标志,再没有其他连在一起的建筑了。一切当年的闪耀均不复存在,只剩下铁皮棚屋上斑驳褪色的女子团伙宣传画。贝极星透过雾气在闪闪发光,月亮也升到了空中,因而夜晚并不显得黑暗。我依稀能辨别出枝江大厦的每一个部分,哪儿曾是夜谈会上扫地机停留的地方,哪儿曾是大门,哪儿曾放着螺蛳粉味薯片。我一一回忆怀念,忽然看见一个孤独的身影,这个身影迟疑了一下,同时我也惊叫了出来。“嘉然小姐!”“我奇怪你怎么还认得出我,我完全变了。”确实她的青春艳丽已经消逝,然而她那难以言表的端庄华丽,她那难以言表的迷人妩媚却依旧当年。所有这些美的诱惑,从前我都见过,而我以前所没有见过的是她那一对眼睛,从前她的双眸总闪着傲气,如今却闪着凄凉酸楚的光。我们坐在附近的一张长椅上,我说道:“多少年如流云般过去,嘉然小姐,你时常回到这里吗?”“我一直没有回来过。”“我也没有。”月亮开始上升,邀游夜空,我脑海中出现了贝拉注视着白色月亮的宁静目光。嘉然小姐终于打破了我们之间的沉默。“我一直在希望有一天能回来看看,可是各种各样的情况使我不能回来。”月光和她的泪珠融合在一起,她没有意识到我已经察觉,想抑制住自己的情感,以平静的语气说道,“我时常想到你。”“真的?”“特别是近些日子,我更常想到你。虽然我生活中有一段很长的艰苦日子,但是我不会去想。自从我个人的情况不如意后,这些口忆就不得不在我心头占一席之地。”“你永远在我的心里。”我答道。我们又一次沉默无言,直到她打破沉寂。“我没有想到,”嘉然说道,“我到这里来和故地告别,竟然又是和你告别,我感到很高兴。”“嘉然小姐,和我又一次分别,你高兴吗?可是对我来说,上次分别时的悲伤和痛苦永远地萦绕在我的记忆之中。”“可是,你上次不是对我说过,”嘉然答道,“但愿圣嘉然保佑你。你上次能这么对我说,你现在也能毫不犹豫地这样对我说,但我并不是什么圣嘉然。多年来的痛苦让我受尽折磨,但是希望你像从前一样体谅我,善待我,并且告诉我,我俩仍是朋友。”“我俩仍是朋友。”我说着站起身,并俯身扶她从长椅上站了起来。“我们虽然分离,但愿情意长存。”嘉然说道。我把她的手握在自己手中,一同走出这片废墟,夜雾也正开始消散。一片广阔的静寂沉浸在月色之中,似乎向我表明,我和她将永远一起,不再分离。 +我和她已经冷战很久了,她画她的画,我看我的报,养我的花。我们中间隔着薄薄一层栅栏,却不曾互相道过早安晚安,我祈祷,有一位天使来拯救我们岌岌可危的爱情。羽毛如雪洁白,天生气质优雅的一只鹅,他是天使派来的吗,我想在它把我的拖鞋叼走,把衣服拖得到处都是的时候,我的心里开始怀疑自己祈祷的虔诚。淘气的小鹅它把我们的花园弄得一团糟,我弄碎了她的花瓶,她剪断了我的花朵,脏衣服满地都是,但是啊,虽然是互相埋怨,但好久没和她说过话了,虽然经历岁月的痕迹,她的脸也不再年轻充满活力,但她还是像从前那样,吵架笑出来的话,不就无法进行下去了吗。“我们和好吧”“好”我和她携手把隔离两边花园的栅栏拆了,牵着手目送那只纯白的小天使离开。原来你真的是天使派来拯救我的呀,小鹅。 +我一边办公,一边看着在第五人格里扮演求生者重启一台又一台发电机成功逃出生天的gamer向晚,满怀羡慕。夸张点说,嫉妒得我眼睛比手里的烟头还红。告诉你们一个秘密,其实我也是求生者,你们也是。电话铃突然响起,我一扫号码腰立刻矮下半截:“喂,经理,是我是我,那个设计您不满意我可以改嘛,全部改掉?好的好的。”我颤颤巍巍地撂下电话,一边重新修改产品一边继续沉思。你看:上司和我、甲方和乙方、跑的和抓的、鼠和猫、求生者与妖怪、某种场合下的S和M,这个世界上总要有个矛盾,矛盾当事人总要以这种形式体现出来。而我似乎总是处在被动的一方(当然也没人让我选过),并对这种境遇见怪不怪。我有时会觉得SM其实是一种相当和谐的关系,因为至少他们偶尔会爱上彼此,而上司决不会对我有半个好脸色。而且我听闻SM会在每场游戏开始前设定一个安全词,放游戏里叫投降,这可以让求生者在感到极度痛苦时结束游戏,避免不必要的损失。这简直令我嫉妒得发狂,我在现实生活折磨的二十年里可从来没有安全词!岂止没有安全词,我甚至都不能像游戏里求生者受伤那样大声哀嚎。因为现实是个面子社会,里子流血面子总得兜住。那怕你的心已经被戳得千疮百孔想花洒那样往外喷番茄汁,你也得对同事家人笑一笑。失去尚可,失败无赦,一旦痛呼出来,就彻底失败了。你以为“别人家的小孩”成绩优异自律自强,可能他内心已经被现实整得口球都带上了;你以为职场同事一个个西装革履,可能拉开就是一身龟甲缚。电话再次响起,我接起电话:“经理,什么,已经有人完成了?不采用了?哦,好的好的,没关系没关系。”妈的,为什么我一想到现实里并不是向晚玩的游戏那样四个人同心同德逃出生天,而是筋疲力竭地互相滴蜡油来竞争一个生存名额,我就止不住地流下泪来。 \ No newline at end of file From 178b55ad52fc8b112e2b9cd170532c0a0d870c58 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 18:52:41 +0800 Subject: [PATCH 44/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_diana/data/text.go | 4 ++++ plugin_diana/tools/convert.go | 12 ++++++++++-- 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/plugin_diana/data/text.go b/plugin_diana/data/text.go index 91a808ab..9bceff13 100644 --- a/plugin_diana/data/text.go +++ b/plugin_diana/data/text.go @@ -1,3 +1,4 @@ +// Package data 加载位于 datapath 的小作文 package data import ( @@ -13,6 +14,7 @@ const ( var ( compo Composition + // 小作文数组 Array []string ) @@ -29,6 +31,7 @@ func init() { }() } +// 加载小作文 func LoadText() error { if _, err := os.Stat(pbfile); err == nil || os.IsExist(err) { f, err := os.Open(pbfile) @@ -46,6 +49,7 @@ func LoadText() error { return nil } +// 添加小作文 func AddText(txt string) error { if txt != "" { compo.Array = append(compo.Array, txt) diff --git a/plugin_diana/tools/convert.go b/plugin_diana/tools/convert.go index a462a818..41ff1323 100644 --- a/plugin_diana/tools/convert.go +++ b/plugin_diana/tools/convert.go @@ -3,6 +3,7 @@ package main import ( "bufio" + "fmt" "os" "github.com/FloatTech/ZeroBot-Plugin/plugin_diana/data" @@ -27,7 +28,7 @@ func main() { scanner := bufio.NewScanner(file) // optionally, resize scanner's capacity for lines over 64K, see next example for scanner.Scan() { - //fmt.Println(scanner.Text()) + // fmt.Println(scanner.Text()) compo.Array = append(compo.Array, scanner.Text()) } @@ -39,6 +40,13 @@ func main() { f, err1 := os.OpenFile(os.Args[2], os.O_WRONLY|os.O_TRUNC|os.O_CREATE, 0644) if err1 == nil { defer f.Close() - f.Write(data) + _, err2 := f.Write(data) + if err2 == nil { + fmt.Println("成功") + } else { + panic(err2) + } + } else { + panic(err1) } } From c53c644a8c563d8f22f30b1aab252de6a1f09469 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 18:56:26 +0800 Subject: [PATCH 45/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_diana/bing.go | 2 +- plugin_diana/data/text.go | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/plugin_diana/bing.go b/plugin_diana/bing.go index b5ea3178..c8e1c8ef 100644 --- a/plugin_diana/bing.go +++ b/plugin_diana/bing.go @@ -11,7 +11,7 @@ import ( "github.com/wdvxdr1123/ZeroBot/message" ) -const yamai = "贝拉抽我🥵嘉然骑在我背上🥵晚晚踩我🥵乃琳坐在王座是用看垃圾的眼神看我🥵🥵珈乐踢我🥵🥵,把我眼睛蒙住然后五只脚一起踩我🥵还让我猜脚是谁的,猜错了给我劈眼一铁棍🥵​" +const yamai = "贝拉抽我\u200b嘉然骑在我背上\u200b晚晚踩我\u200b乃琳坐在王座是用看垃圾的眼神看我\u200b\u200b珈乐踢我\u200b\u200b,把我眼睛蒙住然后五只脚一起踩我\u200b还让我猜脚是谁的,猜错了给我劈眼一铁棍\u200b​" func init() { // 随机发送一篇上面的小作文 diff --git a/plugin_diana/data/text.go b/plugin_diana/data/text.go index 9bceff13..950a00a8 100644 --- a/plugin_diana/data/text.go +++ b/plugin_diana/data/text.go @@ -31,7 +31,7 @@ func init() { }() } -// 加载小作文 +// LoadText 加载小作文 func LoadText() error { if _, err := os.Stat(pbfile); err == nil || os.IsExist(err) { f, err := os.Open(pbfile) @@ -49,7 +49,7 @@ func LoadText() error { return nil } -// 添加小作文 +// AddText 添加小作文 func AddText(txt string) error { if txt != "" { compo.Array = append(compo.Array, txt) From 43cd33156baab1f9ec3721dc47f692dff5d6cab0 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 19:04:08 +0800 Subject: [PATCH 46/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_minecraft/manager.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugin_minecraft/manager.go b/plugin_minecraft/manager.go index 39149b38..d0f1bf74 100644 --- a/plugin_minecraft/manager.go +++ b/plugin_minecraft/manager.go @@ -10,7 +10,7 @@ import ( "github.com/wdvxdr1123/ZeroBot/message" ) -// 此功能实现依赖MCSManager项目对服务器的管理api,mc服务器如果没有在该管理平台部署此功能无效 +// 此功能实现依赖MCSManager项目对服务器的管理api,mc服务器如果没有在该管理平台部署此功能无效 // 项目地址: https://github.com/Suwings/MCSManager // 项目的api文档: https://github.com/Suwings/MCSManager/wiki/API-Documentation From 9f99c063f0e9191581af85d1316b47448a958f25 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 19:04:12 +0800 Subject: [PATCH 47/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 4 ++++ data/Diana/text.pb | 1 + plugin_diana/bing.go | 9 ++++----- plugin_diana/tools/text.txt | 1 + 4 files changed, 10 insertions(+), 5 deletions(-) diff --git a/README.md b/README.md index 83e3d90d..0929aec6 100644 --- a/README.md +++ b/README.md @@ -91,10 +91,14 @@ - 嘉然 `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_diana"` - [x] @BOT 小作文 - [x] @BOT 发大病 + - [x] @BOT 教你一篇小作文[作文] - AIfalse `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_AIfalse"` - [x] 查询计算机当前活跃度 [身体检查] - [ ] 简易语音 - [ ] 爬图合成 [@xxx] +- minecraft `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_minecraft"` + - [x] 具体指令看代码 + - [x] 注:此功能实现依赖[MCSManager](https://github.com/Suwings/MCSManager)项目对服务器的管理api,mc服务器如果没有在该管理平台部署此功能无效 - TODO... ### 使用方法 diff --git a/data/Diana/text.pb b/data/Diana/text.pb index f790b917..e949f683 100644 --- a/data/Diana/text.pb +++ b/data/Diana/text.pb @@ -1,4 +1,5 @@ +贝拉抽我🥵嘉然骑在我背上🥵晚晚踩我🥵乃琳坐在王座是用看垃圾的眼神看我🥵🥵珈乐踢我🥵🥵,把我眼睛蒙住然后五只脚一起踩我🥵还让我猜脚是谁的,猜错了给我劈眼一铁棍🥵 我好想做嘉然小姐的狗啊。可是嘉然小姐说她喜欢的是猫,我哭了。我知道既不是狗也不是猫的我为什么要哭的。因为我其实是一只老鼠。我从没奢望嘉然小姐能喜欢自己。我明白的,所有人都喜欢理解余裕上手天才打钱的萌萌的狗狗或者猫猫,没有人会喜欢阴湿带病的老鼠。但我还是问了嘉然小姐:“我能不能做你的狗?”我知道我是注定做不了狗的。但如果她喜欢狗,我就可以一直在身边看着她了,哪怕她怀里抱着的永远都是狗。可是她说喜欢的是猫。她现在还在看着我,还在逗我开心,是因为猫还没有出现,只有我这老鼠每天蹑手蹑脚地从洞里爬出来,远远地和她对视。等她喜欢的猫来了的时候,我就该重新滚回我的洞了吧。但我还是好喜欢她,她能在我还在她身边的时候多看我几眼吗?嘉然小姐说接下来的每个圣诞夜都要和大家一起过。我不知道大家指哪些人。好希望这个集合能够对我做一次胞吞。猫猫还在害怕嘉然小姐。我会去把她爱的猫猫引来的。我知道稍有不慎,我就会葬身猫口。那时候嘉然小姐大概会把我的身体好好地装起来扔到门外吧。那我就成了一包鼠条,嘻嘻。我希望她能把我扔得近一点,因为我还是好喜欢她。会一直喜欢下去的。我的灵魂透过窗户向里面看去,挂着的铃铛在轻轻鸣响,嘉然小姐慵懒地靠在沙发上,表演得非常温顺的橘猫坐在她的肩膀。壁炉的火光照在她的脸庞,我冻僵的心脏在风里微微发烫。 ダイアナさんの犬になりたいな.けど ダイアナさんが「猫が好き」と言った あさりと僕は泣いてしまった.猫でも犬でもない僕が 何故泣いたのかな 僕は知っていた.何故なら 僕は鼠だったからさ~..一度もダイアナさんに好かれることを望まながった .僕はわがっていた 誰もかも理解余裕上手天才の可愛い金持ちの犬か猫がすきってことを.陰キャで汚らわし鼠は誰も好かんのだ..それでもDianaさんに聞いてみた:Dianaさんの犬になっても良いですかと.僕には一生犬になれないことは分かっている.でももし彼女は犬が好きだったら 僕はずっと傍で見ていられる.それはいつも違ういぬをだいいているとしても..けれど彼女は猫が好きだった.彼女は今にも僕を見ている ぼくを楽しませてくれる それは猫がまだ表れていないから.ただこの鼠が毎日こそこそと穴から出て 遠くから目を合っている.彼女の好きな猫が現れたら 僕は穴に戻るしかないな..でもやっぱり彼女が好きでいられない 僕がまだ傍にいるときぐらい もうちょとみてくれるのかな.Dianaさんがこれから毎回のクリスマスみんなと一緒に過ごすで言った みんながどの渡りのみんなかな.僕にも中に入れたれいいな..猫はまだまだDianaさんを怖がっている.僕が彼女の愛する猫を引き付けるよ.少しのミスで猫の口に死ぬことはわがっている.その時になるとたぶんDianaさんは僕の体をちゃんと包み込んで 玄関外に捨てるでしょ.それで僕はフライト鼠になった くす.彼女に少し近く捨ててほしいな だってやっぱり好きだから それずっと好きでいる..僕のたましは窓を越して中を見る 吊っている鈴が少し響って.Dianaさんはだらりとソファーに寄りかかて 手慣れているふりをする橘猫が彼女の肩に座って.暖炉の光が彼女の顔を照らした 凍り付いた僕の心臓はかぜの中で熱くなっていく 枝江小镇新来了一位修女,善良温柔的修女。她不爱讲话,只是微笑着面对每一个对她祷告的人。有的人希望孩子健康,有的人希望庄稼熬过冬天,有的人希望能挣到钱养活家人。。。。她都用心听着,微笑的回应着。她身材矮小,但是却让人觉得充满智慧;她沉默寡言,但是却会让人无比信赖。这是她任职快满一个月的时候,教堂发生了大事,一个醉汉发现神职人员利用教堂在深夜进行大批资金流入,醉汉传的神乎其神,三人成虎最终引起审判官前来调查。教主被带走,教堂除了那位茫然的新来修女其他人一哄而散。修女被迫承担着本不应该属于她的责难,辱骂,但是她每天都认真的向主祷告,倾听来教堂之人的倾诉。可是根本没有人向她倾诉,来的人不是在骂她,就是在发泄生活的不满。她一己之力拼命承担,没人知道是什么使她如此坚持。直到审判官带回了教主,告诉镇民那是教主在中央主教那里得到的,目的是为镇民熬过冬天所需要买粮食的钱财。一时间镇民欢呼起教主,感谢主的庇护,更多的人开始更加爱上了那个修女。有的人把她比作玛利亚,有些人把她奉为神明,她都一一拒绝了。细心的镇民会发现这位修女变了,变得话多起来了,也变得更喜欢宅在教堂里了,也变得离镇民距离更远了。一切好像又变回原来平和的小镇,每个对修女的加害者每天微笑着向微笑着的修女打招呼,每个镇民还是会去教堂祈祷,去倾诉,去向一个原来被他们亲手辱骂的人祷告,希望得到主的关照,包括那个醉汉。没人能惩罚那些镇民,很多人都已经“忘记”当初为什么要那样做,包括那个醉汉,只剩下一个经常宅在教堂里的修女,她始终记得一切。 diff --git a/plugin_diana/bing.go b/plugin_diana/bing.go index c8e1c8ef..3faf6f71 100644 --- a/plugin_diana/bing.go +++ b/plugin_diana/bing.go @@ -11,20 +11,19 @@ import ( "github.com/wdvxdr1123/ZeroBot/message" ) -const yamai = "贝拉抽我\u200b嘉然骑在我背上\u200b晚晚踩我\u200b乃琳坐在王座是用看垃圾的眼神看我\u200b\u200b珈乐踢我\u200b\u200b,把我眼睛蒙住然后五只脚一起踩我\u200b还让我猜脚是谁的,猜错了给我劈眼一铁棍\u200b​" - func init() { // 随机发送一篇上面的小作文 zero.OnFullMatch("小作文", zero.OnlyToMe). Handle(func(ctx *zero.Ctx) { rand.Seed(time.Now().UnixNano()) - ctx.SendChain(message.Text(data.Array[rand.Intn(len(data.Array))])) + // 绕过第一行发病 + ctx.SendChain(message.Text(data.Array[rand.Intn(len(data.Array)-1)+1])) }) - // 逆天 zero.OnFullMatch("发大病", zero.OnlyToMe). Handle(func(ctx *zero.Ctx) { - ctx.Send(yamai) + // 第一行是发病 + ctx.Send(data.Array[0]) }) // 增加小作文 zero.OnRegex(`^教你一篇小作文(.*)$`, zero.AdminPermission). diff --git a/plugin_diana/tools/text.txt b/plugin_diana/tools/text.txt index c4679011..011eea88 100644 --- a/plugin_diana/tools/text.txt +++ b/plugin_diana/tools/text.txt @@ -1,3 +1,4 @@ +贝拉抽我🥵嘉然骑在我背上🥵晚晚踩我🥵乃琳坐在王座是用看垃圾的眼神看我🥵🥵珈乐踢我🥵🥵,把我眼睛蒙住然后五只脚一起踩我🥵还让我猜脚是谁的,猜错了给我劈眼一铁棍🥵 我好想做嘉然小姐的狗啊。可是嘉然小姐说她喜欢的是猫,我哭了。我知道既不是狗也不是猫的我为什么要哭的。因为我其实是一只老鼠。我从没奢望嘉然小姐能喜欢自己。我明白的,所有人都喜欢理解余裕上手天才打钱的萌萌的狗狗或者猫猫,没有人会喜欢阴湿带病的老鼠。但我还是问了嘉然小姐:“我能不能做你的狗?”我知道我是注定做不了狗的。但如果她喜欢狗,我就可以一直在身边看着她了,哪怕她怀里抱着的永远都是狗。可是她说喜欢的是猫。她现在还在看着我,还在逗我开心,是因为猫还没有出现,只有我这老鼠每天蹑手蹑脚地从洞里爬出来,远远地和她对视。等她喜欢的猫来了的时候,我就该重新滚回我的洞了吧。但我还是好喜欢她,她能在我还在她身边的时候多看我几眼吗?嘉然小姐说接下来的每个圣诞夜都要和大家一起过。我不知道大家指哪些人。好希望这个集合能够对我做一次胞吞。猫猫还在害怕嘉然小姐。我会去把她爱的猫猫引来的。我知道稍有不慎,我就会葬身猫口。那时候嘉然小姐大概会把我的身体好好地装起来扔到门外吧。那我就成了一包鼠条,嘻嘻。我希望她能把我扔得近一点,因为我还是好喜欢她。会一直喜欢下去的。我的灵魂透过窗户向里面看去,挂着的铃铛在轻轻鸣响,嘉然小姐慵懒地靠在沙发上,表演得非常温顺的橘猫坐在她的肩膀。壁炉的火光照在她的脸庞,我冻僵的心脏在风里微微发烫。 ダイアナさんの犬になりたいな.けど ダイアナさんが「猫が好き」と言った あさりと僕は泣いてしまった.猫でも犬でもない僕が 何故泣いたのかな 僕は知っていた.何故なら 僕は鼠だったからさ~..一度もダイアナさんに好かれることを望まながった .僕はわがっていた 誰もかも理解余裕上手天才の可愛い金持ちの犬か猫がすきってことを.陰キャで汚らわし鼠は誰も好かんのだ..それでもDianaさんに聞いてみた:Dianaさんの犬になっても良いですかと.僕には一生犬になれないことは分かっている.でももし彼女は犬が好きだったら 僕はずっと傍で見ていられる.それはいつも違ういぬをだいいているとしても..けれど彼女は猫が好きだった.彼女は今にも僕を見ている ぼくを楽しませてくれる それは猫がまだ表れていないから.ただこの鼠が毎日こそこそと穴から出て 遠くから目を合っている.彼女の好きな猫が現れたら 僕は穴に戻るしかないな..でもやっぱり彼女が好きでいられない 僕がまだ傍にいるときぐらい もうちょとみてくれるのかな.Dianaさんがこれから毎回のクリスマスみんなと一緒に過ごすで言った みんながどの渡りのみんなかな.僕にも中に入れたれいいな..猫はまだまだDianaさんを怖がっている.僕が彼女の愛する猫を引き付けるよ.少しのミスで猫の口に死ぬことはわがっている.その時になるとたぶんDianaさんは僕の体をちゃんと包み込んで 玄関外に捨てるでしょ.それで僕はフライト鼠になった くす.彼女に少し近く捨ててほしいな だってやっぱり好きだから それずっと好きでいる..僕のたましは窓を越して中を見る 吊っている鈴が少し響って.Dianaさんはだらりとソファーに寄りかかて 手慣れているふりをする橘猫が彼女の肩に座って.暖炉の光が彼女の顔を照らした 凍り付いた僕の心臓はかぜの中で熱くなっていく 枝江小镇新来了一位修女,善良温柔的修女。她不爱讲话,只是微笑着面对每一个对她祷告的人。有的人希望孩子健康,有的人希望庄稼熬过冬天,有的人希望能挣到钱养活家人。。。。她都用心听着,微笑的回应着。她身材矮小,但是却让人觉得充满智慧;她沉默寡言,但是却会让人无比信赖。这是她任职快满一个月的时候,教堂发生了大事,一个醉汉发现神职人员利用教堂在深夜进行大批资金流入,醉汉传的神乎其神,三人成虎最终引起审判官前来调查。教主被带走,教堂除了那位茫然的新来修女其他人一哄而散。修女被迫承担着本不应该属于她的责难,辱骂,但是她每天都认真的向主祷告,倾听来教堂之人的倾诉。可是根本没有人向她倾诉,来的人不是在骂她,就是在发泄生活的不满。她一己之力拼命承担,没人知道是什么使她如此坚持。直到审判官带回了教主,告诉镇民那是教主在中央主教那里得到的,目的是为镇民熬过冬天所需要买粮食的钱财。一时间镇民欢呼起教主,感谢主的庇护,更多的人开始更加爱上了那个修女。有的人把她比作玛利亚,有些人把她奉为神明,她都一一拒绝了。细心的镇民会发现这位修女变了,变得话多起来了,也变得更喜欢宅在教堂里了,也变得离镇民距离更远了。一切好像又变回原来平和的小镇,每个对修女的加害者每天微笑着向微笑着的修女打招呼,每个镇民还是会去教堂祈祷,去倾诉,去向一个原来被他们亲手辱骂的人祷告,希望得到主的关照,包括那个醉汉。没人能惩罚那些镇民,很多人都已经“忘记”当初为什么要那样做,包括那个醉汉,只剩下一个经常宅在教堂里的修女,她始终记得一切。 From ba78d521f54918d6f3226db8e266d8c181687fb7 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 19:11:09 +0800 Subject: [PATCH 48/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/golint.yml | 37 +++++++++++++++++++++--------------- 1 file changed, 22 insertions(+), 15 deletions(-) diff --git a/.github/workflows/golint.yml b/.github/workflows/golint.yml index 94eaa98b..0b19b1ee 100644 --- a/.github/workflows/golint.yml +++ b/.github/workflows/golint.yml @@ -1,24 +1,31 @@ -name: Lint - +name: golangci-lint on: [push] - jobs: golangci: - name: lint_golangci-lint + name: lint runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2.3.4 - + - uses: actions/checkout@v2 - name: golangci-lint - uses: golangci/golangci-lint-action@v2.5.2 + uses: golangci/golangci-lint-action@v2 with: + # Optional: version of golangci-lint to use in form of v1.2 or v1.2.3 or `latest` to use the latest version version: latest - - name: Commit back - continue-on-error: true - run: | - git config --local user.name 'github-actions[bot]' - git config --local user.email '41898282+github-actions[bot]@users.noreply.github.com' - git add --all - git commit -m "🎨 改进代码样式" - git push + # Optional: working directory, useful for monorepos + # working-directory: somedir + + # Optional: golangci-lint command line arguments. + # args: --issues-exit-code=0 + + # Optional: show only new issues if it's a pull request. The default value is `false`. + # only-new-issues: true + + # Optional: if set to true then the action will use pre-installed Go. + # skip-go-installation: true + + # Optional: if set to true then the action don't cache or restore ~/go/pkg. + # skip-pkg-cache: true + + # Optional: if set to true then the action don't cache or restore ~/.cache/go-build. + # skip-build-cache: true From 4d4428047a18fcd523e21fc4d6a26285a3678619 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 19:13:40 +0800 Subject: [PATCH 49/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/golint.yml | 31 ------------------------------- .github/workflows/suggester.yml | 31 +++++++++++++++++++++---------- 2 files changed, 21 insertions(+), 41 deletions(-) delete mode 100644 .github/workflows/golint.yml diff --git a/.github/workflows/golint.yml b/.github/workflows/golint.yml deleted file mode 100644 index 0b19b1ee..00000000 --- a/.github/workflows/golint.yml +++ /dev/null @@ -1,31 +0,0 @@ -name: golangci-lint -on: [push] -jobs: - golangci: - name: lint - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - name: golangci-lint - uses: golangci/golangci-lint-action@v2 - with: - # Optional: version of golangci-lint to use in form of v1.2 or v1.2.3 or `latest` to use the latest version - version: latest - - # Optional: working directory, useful for monorepos - # working-directory: somedir - - # Optional: golangci-lint command line arguments. - # args: --issues-exit-code=0 - - # Optional: show only new issues if it's a pull request. The default value is `false`. - # only-new-issues: true - - # Optional: if set to true then the action will use pre-installed Go. - # skip-go-installation: true - - # Optional: if set to true then the action don't cache or restore ~/go/pkg. - # skip-pkg-cache: true - - # Optional: if set to true then the action don't cache or restore ~/.cache/go-build. - # skip-build-cache: true diff --git a/.github/workflows/suggester.yml b/.github/workflows/suggester.yml index 022fdf2e..ffd04262 100644 --- a/.github/workflows/suggester.yml +++ b/.github/workflows/suggester.yml @@ -1,20 +1,31 @@ -name: Suggester - +name: golangci-lint on: [pull_request] - jobs: golangci: name: lint runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2.3.4 - + - uses: actions/checkout@v2 - name: golangci-lint - uses: golangci/golangci-lint-action@v2.5.2 + uses: golangci/golangci-lint-action@v2 with: + # Optional: version of golangci-lint to use in form of v1.2 or v1.2.3 or `latest` to use the latest version version: latest - - name: Suggester - uses: reviewdog/action-suggester@v1.0.1 - with: - tool_name: golangci-lint \ No newline at end of file + # Optional: working directory, useful for monorepos + # working-directory: somedir + + # Optional: golangci-lint command line arguments. + # args: --issues-exit-code=0 + + # Optional: show only new issues if it's a pull request. The default value is `false`. + # only-new-issues: true + + # Optional: if set to true then the action will use pre-installed Go. + # skip-go-installation: true + + # Optional: if set to true then the action don't cache or restore ~/go/pkg. + # skip-pkg-cache: true + + # Optional: if set to true then the action don't cache or restore ~/.cache/go-build. + # skip-build-cache: true From c3c82e00229f35e439ac1b1d4f49082e0d0c22df Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 19:22:40 +0800 Subject: [PATCH 50/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/suggester.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/suggester.yml b/.github/workflows/suggester.yml index ffd04262..13d7762a 100644 --- a/.github/workflows/suggester.yml +++ b/.github/workflows/suggester.yml @@ -16,7 +16,7 @@ jobs: # working-directory: somedir # Optional: golangci-lint command line arguments. - # args: --issues-exit-code=0 + args: -D warining # Optional: show only new issues if it's a pull request. The default value is `false`. # only-new-issues: true From 1f063d686a4295040665c88c3d3fc6d1118052cf Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 19:25:53 +0800 Subject: [PATCH 51/79] ... --- .github/workflows/suggester.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/suggester.yml b/.github/workflows/suggester.yml index 13d7762a..ffd04262 100644 --- a/.github/workflows/suggester.yml +++ b/.github/workflows/suggester.yml @@ -16,7 +16,7 @@ jobs: # working-directory: somedir # Optional: golangci-lint command line arguments. - args: -D warining + # args: --issues-exit-code=0 # Optional: show only new issues if it's a pull request. The default value is `false`. # only-new-issues: true From fcc92b698fc50d0b8d923eae562bf3f8d6375a9b Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 19:31:01 +0800 Subject: [PATCH 52/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/suggester.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/suggester.yml b/.github/workflows/suggester.yml index ffd04262..8e26d0a5 100644 --- a/.github/workflows/suggester.yml +++ b/.github/workflows/suggester.yml @@ -16,7 +16,7 @@ jobs: # working-directory: somedir # Optional: golangci-lint command line arguments. - # args: --issues-exit-code=0 + args: -e "^Warning:.*" # Optional: show only new issues if it's a pull request. The default value is `false`. # only-new-issues: true From a0da37d53b96bed7dba73db94f292e74d111cb97 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 19:35:21 +0800 Subject: [PATCH 53/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/suggester.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/suggester.yml b/.github/workflows/suggester.yml index 8e26d0a5..cb3ce157 100644 --- a/.github/workflows/suggester.yml +++ b/.github/workflows/suggester.yml @@ -1,4 +1,4 @@ -name: golangci-lint +name: Lint on: [pull_request] jobs: golangci: @@ -16,7 +16,7 @@ jobs: # working-directory: somedir # Optional: golangci-lint command line arguments. - args: -e "^Warning:.*" + args: -e ".*Warning:.*" # Optional: show only new issues if it's a pull request. The default value is `false`. # only-new-issues: true From 26f51dae862a3f11fe0873ed7f471b3c3b6ca1b5 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 19:54:46 +0800 Subject: [PATCH 54/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/suggester.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/suggester.yml b/.github/workflows/suggester.yml index cb3ce157..ae7f8039 100644 --- a/.github/workflows/suggester.yml +++ b/.github/workflows/suggester.yml @@ -16,13 +16,13 @@ jobs: # working-directory: somedir # Optional: golangci-lint command line arguments. - args: -e ".*Warning:.*" + args: -e nolintlint # Optional: show only new issues if it's a pull request. The default value is `false`. # only-new-issues: true # Optional: if set to true then the action will use pre-installed Go. - # skip-go-installation: true + skip-go-installation: true # Optional: if set to true then the action don't cache or restore ~/go/pkg. # skip-pkg-cache: true From 70a970679f07e622a0c0e294b160924215aa7b76 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 20:02:26 +0800 Subject: [PATCH 55/79] =?UTF-8?q?=F0=9F=92=A9=F0=9F=91=8C=20make=20lint=20?= =?UTF-8?q?happy?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/suggester.yml | 4 ++-- plugin_diana/data/text.go | 2 +- plugin_github/repo_searcher.go | 3 ++- 3 files changed, 5 insertions(+), 4 deletions(-) diff --git a/.github/workflows/suggester.yml b/.github/workflows/suggester.yml index ae7f8039..a0c6b202 100644 --- a/.github/workflows/suggester.yml +++ b/.github/workflows/suggester.yml @@ -16,13 +16,13 @@ jobs: # working-directory: somedir # Optional: golangci-lint command line arguments. - args: -e nolintlint + # args: --issues-exit-code=0 # Optional: show only new issues if it's a pull request. The default value is `false`. # only-new-issues: true # Optional: if set to true then the action will use pre-installed Go. - skip-go-installation: true + # skip-go-installation: true # Optional: if set to true then the action don't cache or restore ~/go/pkg. # skip-pkg-cache: true diff --git a/plugin_diana/data/text.go b/plugin_diana/data/text.go index 950a00a8..530b99e6 100644 --- a/plugin_diana/data/text.go +++ b/plugin_diana/data/text.go @@ -14,7 +14,7 @@ const ( var ( compo Composition - // 小作文数组 + // Array 小作文数组 Array []string ) diff --git a/plugin_github/repo_searcher.go b/plugin_github/repo_searcher.go index a119a8c8..036d2185 100644 --- a/plugin_github/repo_searcher.go +++ b/plugin_github/repo_searcher.go @@ -91,7 +91,8 @@ func netGet(dest string, header http.Header) ([]byte, error) { } if code := resp.StatusCode; code != 200 { // 如果返回不是200则立刻抛出错误 - return nil, errors.New(fmt.Sprintf("code %d", code)) + errmsg := fmt.Sprintf("code %d", code) + return nil, errors.New(errmsg) } return body, nil } From 80265d65136c4963ec07900777e6be7196b3d0ad Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 20:58:23 +0800 Subject: [PATCH 56/79] =?UTF-8?q?=E2=9C=8F=EF=B8=8F=20=E5=AE=8C=E5=96=84?= =?UTF-8?q?=E8=87=AA=E8=BF=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 77 ++++++++++++++++++++++++++++++++++++++----------------- 1 file changed, 54 insertions(+), 23 deletions(-) diff --git a/README.md b/README.md index 0929aec6..48d12be3 100644 --- a/README.md +++ b/README.md @@ -1,8 +1,10 @@
OneBot-YaYa
-

ZeroBot-Plugin

+

ZeroBot-Plugin

ZeroBot-Plugin 是 ZeroBot 的 实用插件合集

+ + [![YAYA](https://img.shields.io/badge/OneBot-YaYa-green.svg?style=social&logo=appveyor)](https://github.com/Yiwen-Chan/OneBot-YaYa) [![GOCQ](https://img.shields.io/badge/OneBot-MiraiGo-green.svg?style=social&logo=appveyor)](https://github.com/Mrs4s/go-cqhttp) [![OICQ](https://img.shields.io/badge/OneBot-OICQ-green.svg?style=social&logo=appveyor)](https://github.com/takayama-lily/node-onebot) @@ -10,25 +12,28 @@ [![Go Report Card](https://goreportcard.com/badge/github.com/Yiwen-Chan/ZeroBot-Plugin?style=flat-square&logo=go)](https://goreportcard.com/report/github.com/github.com/Yiwen-Chan/ZeroBot-Plugin) [![Badge](https://img.shields.io/badge/onebot-v11-black?logo=)](https://github.com/howmanybots/onebot) -[![Badge](https://img.shields.io/badge/zerobot-v1.2.1-black?style=flat-square&logo=go)](https://github.com/wdvxdr1123/ZeroBot) +[![Badge](https://img.shields.io/badge/zerobot-v1.2.2-black?style=flat-square&logo=go)](https://github.com/wdvxdr1123/ZeroBot) [![License](https://img.shields.io/github/license/Yiwen-Chan/OneBot-YaYa.svg?style=flat-square&logo=gnu)](https://raw.githubusercontent.com/FloatTech/ZeroBot-Plugin/master/LICENSE) [![qq group](https://img.shields.io/badge/group-1048452984-red?style=flat-square&logo=tencent-qq)](https://jq.qq.com/?_wv=1027&k=QMb7x1mM) +[![Compile ZeroBot-Plugin-linux](https://github.com/FloatTech/ZeroBot-Plugin/actions/workflows/linux.yml/badge.svg?branch=master)](https://github.com/FloatTech/ZeroBot-Plugin/actions/workflows/linux.yml) +[![Compile ZeroBot-Plugin-windows](https://github.com/FloatTech/ZeroBot-Plugin/actions/workflows/windows.yml/badge.svg?branch=master)](https://github.com/FloatTech/ZeroBot-Plugin/actions/workflows/windows.yml) +
-### 功能 -- 聊天 `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_chat"` +## 功能 +- **聊天** `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_chat"` - [x] [BOT名字] - [x] [戳一戳BOT] - [x] 空调开 - [x] 空调关 - [x] 群温度 - [x] 设置温度[正整数] -- ATRI `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_atri"` +- **ATRI** `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_atri"` - [x] 具体指令看代码 - 注:本插件基于 [ATRI](https://github.com/Kyomotoi/ATRI) ,为 Golang 移植版 -- 群管 `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_manager"` +- **群管** `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_manager"` - [x] 禁言[@xxx][分钟] - [x] 解除禁言[@xxx] - [x] 我要自闭 [分钟] @@ -54,54 +59,54 @@ - [ ] 撤回[@xxx] [xxx] - [ ] 警告[@xxx] - [x] run[xxx] -- GitHub仓库搜索 `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_github"` +- **GitHub仓库搜索** `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_github"` - [x] >github [xxx] - [x] >github -p [xxx] -- 在线代码运行 `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_runcode"` +- **在线代码运行** `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_runcode"` - [x] >runcode help - [x] >runcode [on/off] - [x] >runcode [language] [code block] -- 点歌 `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_music"` +- **点歌** `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_music"` - [x] 点歌[xxx] - [x] 网易点歌[xxx] - [x] 酷我点歌[xxx] - [x] 酷狗点歌[xxx] -- shindan `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_shindan"` +- **shindan** `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_shindan"` - [x] 今天是什么少女[@xxx] - [x] 异世界转生[@xxx] - [x] 卖萌[@xxx] -- 涩图 `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_setutime"` +- **涩图** `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_setutime"` - [x] 来份[涩图/二次元/风景/车万] - [x] 添加[涩图/二次元/风景/车万][P站图片ID] - [x] 删除[涩图/二次元/风景/车万][P站图片ID] - [x] >setu status -- lolicon `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_lolicon"` +- **lolicon** `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_lolicon"` - [x] 来份萝莉 -- 搜图 `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_saucenao"` +- **搜图** `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_saucenao"` - [x] 以图搜图|搜索图片|以图识图[图片] - [x] 搜图[P站图片ID] -- 随机图片与AI点评 `github.com/FloatTech/ZeroBot-ACGImage` +- **随机图片与AI点评** `github.com/FloatTech/ZeroBot-ACGImage` - [x] 随机图片(评级大于6的图将私发) - [x] 直接随机(无r18检测,务必小心,仅管理可用) - [x] 设置随机图片网址[url] - [x] 太涩了(撤回最近发的图) - [x] 评价图片(发送一张图片让bot评分) -- bilibili `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_bilibili"` +- **bilibili** `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_bilibili"` - [x] >bili info [名字] -- 嘉然 `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_diana"` +- **嘉然** `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_diana"` - [x] @BOT 小作文 - [x] @BOT 发大病 - [x] @BOT 教你一篇小作文[作文] -- AIfalse `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_AIfalse"` +- **AIfalse** `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_AIfalse"` - [x] 查询计算机当前活跃度 [身体检查] - [ ] 简易语音 - [ ] 爬图合成 [@xxx] -- minecraft `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_minecraft"` +- **minecraft** `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_minecraft"` - [x] 具体指令看代码 - [x] 注:此功能实现依赖[MCSManager](https://github.com/Suwings/MCSManager)项目对服务器的管理api,mc服务器如果没有在该管理平台部署此功能无效 -- TODO... +- **TODO...** -### 使用方法 +## 使用方法 本项目符合 [OneBot](https://github.com/howmanybots/onebot) 标准,可基于以下项目与机器人框架/平台进行交互 | 项目地址 | 平台 | 核心作者 | 备注 | @@ -112,13 +117,16 @@ | [yyuueexxiinngg/cqhttp-mirai](https://github.com/yyuueexxiinngg/cqhttp-mirai) | [Mirai](https://github.com/mamoe/mirai) | yyuueexxiinngg | | | [takayama-lily/onebot](https://github.com/takayama-lily/onebot) | [OICQ](https://github.com/takayama-lily/oicq) | takayama | | -#### 本地运行 +### 本地运行 1. 下载安装 [Go](https://studygolang.com/dl/golang/go1.16.2.windows-amd64.msi) 环境 -2. [clone](https://github.com/Yiwen-Chan/ZeroBot-Plugin/archive/master.zip) 本项目,本地解压 +2. 下载本项目[压缩包](https://github.com/Yiwen-Chan/ZeroBot-Plugin/archive/master.zip),本地解压 3. 编辑 main.go 文件,内容按需修改 4. 双击 build.bat 文件 或 直接双击 run.bat 文件 5. 运行 OneBot 框架,并同时运行本插件 +### 编译运行 +> 需要将`data`目录放置到与编译好的可执行文件相同目录下才可正常执行。 + #### 利用 Actions 在线编译 (推荐) 1. 点击右上角 Fork 本项目,并转跳到自己 Fork 的仓库 2. 点击仓库上方的 Actions 按钮,确认使用 Actions @@ -127,7 +135,30 @@ 5. 运行 OneBot 框架,并同时运行本插件 6. 啾咪~ -### 特别感谢 +#### 本地编译/交叉编译 +1. 下载安装 [Go](https://studygolang.com/dl/golang/go1.16.2.windows-amd64.msi) 环境 +2. clone 并进入本项目,下载所需包 +```bash +git clone --depth=1 https://github.com/FloatTech/ZeroBot-Plugin.git +cd ZeroBot-Plugin +go version +go env -w GOPROXY=https://goproxy.cn,direct +go env -w GO111MODULE=auto +go mod tidy +``` +3. 编辑 main.go 文件,内容按需修改 +4. 按照平台输入命令编译,下面举了两个不太常见的例子 +```bash +# 本机平台 +go build -ldflags "-s -w -extldflags '-static-libgo'" -o zerobot +# armv6 Linux 平台 如树莓派 zero W +GOOS=linux GOARCH=arm GOARM=6 CGO_ENABLED=0 go build -ldflags "-s -w -extldflags '-static-libgo'" -o zerobot +# mips Linux 平台 如 路由器 wndr4300 +GOOS=linux GOARCH=mips GOMIPS=softfloat CGO_ENABLED=0 go build -ldflags "-s -w -extldflags '-static-libgo'" -o zerobot +``` +5. 运行 OneBot 框架,并同时运行本插件 + +## 特别感谢 - [ZeroBot](https://github.com/wdvxdr1123/ZeroBot) - [ATRI](https://github.com/Kyomotoi/ATRI) From c7a4d228eff70bca265ceb81a2ff8b9065a1dd51 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 21:06:46 +0800 Subject: [PATCH 57/79] =?UTF-8?q?=E2=9C=8F=EF=B8=8F=20=E5=AE=8C=E5=96=84?= =?UTF-8?q?=E8=87=AA=E8=BF=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 48d12be3..d20cf5d7 100644 --- a/README.md +++ b/README.md @@ -103,7 +103,7 @@ - [ ] 爬图合成 [@xxx] - **minecraft** `import _ "github.com/FloatTech/ZeroBot-Plugin/plugin_minecraft"` - [x] 具体指令看代码 - - [x] 注:此功能实现依赖[MCSManager](https://github.com/Suwings/MCSManager)项目对服务器的管理api,mc服务器如果没有在该管理平台部署此功能无效 + - 注:此功能实现依赖[MCSManager](https://github.com/Suwings/MCSManager)项目对服务器的管理api,mc服务器如果没有在该管理平台部署此功能无效 - **TODO...** ## 使用方法 From 1989d4a61f571e2bc266ea3fb23db49232561524 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 21:23:15 +0800 Subject: [PATCH 58/79] =?UTF-8?q?=E2=9C=A8=20=E5=A2=9E=E5=8A=A0log?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 3 ++- plugin_diana/data/text.go | 2 ++ 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/.gitignore b/.gitignore index 601f1673..e063b380 100644 --- a/.gitignore +++ b/.gitignore @@ -3,4 +3,5 @@ data/SetuTime/search data/manager .idea/ .DS_Store -.vscode \ No newline at end of file +.vscode +.github/workflows/golint.yml diff --git a/plugin_diana/data/text.go b/plugin_diana/data/text.go index 530b99e6..24187ac4 100644 --- a/plugin_diana/data/text.go +++ b/plugin_diana/data/text.go @@ -2,6 +2,7 @@ package data import ( + "fmt" "io" "os" "time" @@ -28,6 +29,7 @@ func init() { if LoadText() == nil { Array = compo.Array } + fmt.Printf("[Diana]读取%d条小作文\n", len(Array)) }() } From ef1981934b57cfcb51418c5807d97d476d38c51b Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 21:44:00 +0800 Subject: [PATCH 59/79] =?UTF-8?q?=E2=9C=8F=EF=B8=8F=20=E5=A2=9E=E5=8A=A0?= =?UTF-8?q?=E5=B0=8F=E4=BD=9C=E6=96=87=E5=AE=9E=E6=97=B6=E5=8F=8D=E5=BA=94?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .golangci.yml | 2 +- plugin_diana/bing.go | 4 ++-- plugin_diana/data/text.go | 12 +++++++----- 3 files changed, 10 insertions(+), 8 deletions(-) diff --git a/.golangci.yml b/.golangci.yml index c26e2510..cc973e9c 100644 --- a/.golangci.yml +++ b/.golangci.yml @@ -4,7 +4,7 @@ linters-settings: ignoretests: true goimports: - local-prefixes: github.com/Yiwen-Chan/ZeroBot-Plugin + local-prefixes: github.com/FloatTech/ZeroBot-Plugin gocritic: disabled-checks: diff --git a/plugin_diana/bing.go b/plugin_diana/bing.go index 3faf6f71..12cde0bf 100644 --- a/plugin_diana/bing.go +++ b/plugin_diana/bing.go @@ -17,13 +17,13 @@ func init() { Handle(func(ctx *zero.Ctx) { rand.Seed(time.Now().UnixNano()) // 绕过第一行发病 - ctx.SendChain(message.Text(data.Array[rand.Intn(len(data.Array)-1)+1])) + ctx.SendChain(message.Text((*data.Array)[rand.Intn(len(*data.Array)-1)+1])) }) // 逆天 zero.OnFullMatch("发大病", zero.OnlyToMe). Handle(func(ctx *zero.Ctx) { // 第一行是发病 - ctx.Send(data.Array[0]) + ctx.Send((*data.Array)[0]) }) // 增加小作文 zero.OnRegex(`^教你一篇小作文(.*)$`, zero.AdminPermission). diff --git a/plugin_diana/data/text.go b/plugin_diana/data/text.go index 24187ac4..b1b17137 100644 --- a/plugin_diana/data/text.go +++ b/plugin_diana/data/text.go @@ -15,8 +15,8 @@ const ( var ( compo Composition - // Array 小作文数组 - Array []string + // Array 小作文数组指针 + Array = &compo.Array ) func init() { @@ -26,10 +26,12 @@ func init() { if err != nil { panic(err) } - if LoadText() == nil { - Array = compo.Array + err1 := LoadText() + if err1 == nil { + fmt.Printf("[Diana]读取%d条小作文\n", len(*Array)) + } else { + fmt.Printf("[Diana]读取小作文错误:%v\n", err1) } - fmt.Printf("[Diana]读取%d条小作文\n", len(Array)) }() } From 9ea41412ad03d3c26e1b5f14fd8b115ea9381de7 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 22:10:35 +0800 Subject: [PATCH 60/79] =?UTF-8?q?=E2=9C=8F=EF=B8=8F=20=E6=A0=87=E5=87=86?= =?UTF-8?q?=E5=8C=96log?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/golint.yml | 31 +++++++++++++++++++++++++++++++ .gitignore | 1 - go.mod | 2 +- go.sum | 4 ++++ main.go | 4 ++-- plugin_diana/data/text.go | 7 ++++--- 6 files changed, 42 insertions(+), 7 deletions(-) create mode 100644 .github/workflows/golint.yml diff --git a/.github/workflows/golint.yml b/.github/workflows/golint.yml new file mode 100644 index 00000000..c07742d4 --- /dev/null +++ b/.github/workflows/golint.yml @@ -0,0 +1,31 @@ +name: PushLint +on: [push] +jobs: + golangci: + name: lint + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v2 + - name: golangci-lint + uses: golangci/golangci-lint-action@v2 + with: + # Optional: version of golangci-lint to use in form of v1.2 or v1.2.3 or `latest` to use the latest version + version: latest + + # Optional: working directory, useful for monorepos + # working-directory: somedir + + # Optional: golangci-lint command line arguments. + # args: --issues-exit-code=0 + + # Optional: show only new issues if it's a pull request. The default value is `false`. + # only-new-issues: true + + # Optional: if set to true then the action will use pre-installed Go. + # skip-go-installation: true + + # Optional: if set to true then the action don't cache or restore ~/go/pkg. + # skip-pkg-cache: true + + # Optional: if set to true then the action don't cache or restore ~/.cache/go-build. + # skip-build-cache: true diff --git a/.gitignore b/.gitignore index e063b380..9842d743 100644 --- a/.gitignore +++ b/.gitignore @@ -4,4 +4,3 @@ data/manager .idea/ .DS_Store .vscode -.github/workflows/golint.yml diff --git a/go.mod b/go.mod index 405ee98b..7491df34 100644 --- a/go.mod +++ b/go.mod @@ -5,7 +5,7 @@ go 1.16 require ( github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd github.com/FloatTech/ZeroBot-ACGImage v1.5.5 - github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4 + github.com/FloatTech/ZeroBot-Plugin-Timer v1.4.2 github.com/StackExchange/wmi v1.2.1 // indirect github.com/golang/protobuf v1.5.2 github.com/robfig/cron v1.2.0 diff --git a/go.sum b/go.sum index c1ac735d..eb9a8334 100644 --- a/go.sum +++ b/go.sum @@ -4,6 +4,10 @@ github.com/FloatTech/ZeroBot-ACGImage v1.5.5 h1:cmAsXHl99RHJR38vQXL+q/U0BGWg5LyM github.com/FloatTech/ZeroBot-ACGImage v1.5.5/go.mod h1:TDGCgGHKjgcnA0akLaEwUcFwL+/ya7p6PZITdJQ1vnQ= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4 h1:nRJqY/S7TRlN32MQGIBH3UWfVrpjxpJXCnp42pd2O2Q= github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= +github.com/FloatTech/ZeroBot-Plugin-Timer v1.4.1 h1:LVSTyfLlhcJEES16r3gyhN2jd2WJUlQiN193f0DdJ7Q= +github.com/FloatTech/ZeroBot-Plugin-Timer v1.4.1/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= +github.com/FloatTech/ZeroBot-Plugin-Timer v1.4.2 h1:w/JerL8DwdyoxZYB4HRMaHANRV2j+r5XxaQhVB0sjBw= +github.com/FloatTech/ZeroBot-Plugin-Timer v1.4.2/go.mod h1:MVOQQ4e6AVGFm993blXXU4Sd6bAsLY2+Zb+/HMrEeEc= github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.3 h1:mMaBe23yg8mk5U0yb9OS9iX/9hju6Dj+Z+Fty18vIhU= github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.3/go.mod h1:swPvVKyXu1YFWZ7Kt6R79LgIa16hs4cE1E5LroBB2SQ= github.com/StackExchange/wmi v1.2.1 h1:VIkavFPXSjcnS+O8yTq7NI32k0R5Aj+v39y29VYDOSA= diff --git a/main.go b/main.go index 38bb2959..1855ce86 100644 --- a/main.go +++ b/main.go @@ -59,9 +59,9 @@ func init() { func main() { fmt.Print( - "====================[ZeroBot-Plugin]====================", + "======================[ZeroBot-Plugin]======================", "\n", strings.Join(content, "\n"), "\n", - "========================================================", + "============================================================\n", ) // 启动打印 zero.Run(zero.Config{ NickName: []string{"椛椛", "ATRI", "atri", "亚托莉", "アトリ"}, diff --git a/plugin_diana/data/text.go b/plugin_diana/data/text.go index b1b17137..10a87e26 100644 --- a/plugin_diana/data/text.go +++ b/plugin_diana/data/text.go @@ -2,10 +2,11 @@ package data import ( - "fmt" "io" "os" "time" + + log "github.com/sirupsen/logrus" ) const ( @@ -28,9 +29,9 @@ func init() { } err1 := LoadText() if err1 == nil { - fmt.Printf("[Diana]读取%d条小作文\n", len(*Array)) + log.Printf("[Diana]读取%d条小作文", len(*Array)) } else { - fmt.Printf("[Diana]读取小作文错误:%v\n", err1) + log.Printf("[Diana]读取小作文错误:%v", err1) } }() } From a861a1d1697a56319b9318e5268b99982800aff6 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 23:24:02 +0800 Subject: [PATCH 61/79] =?UTF-8?q?=E2=9C=A8=20=E5=A2=9E=E5=8A=A0=E9=9B=86?= =?UTF-8?q?=E6=88=90=E5=BA=A6?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- go.mod | 3 +- go.sum | 25 ++------ main.go | 2 +- plugin_acgimage/classify.go | 118 ++++++++++++++++++++++++++++++++++++ plugin_saucenao/searcher.go | 45 +------------- 5 files changed, 126 insertions(+), 67 deletions(-) create mode 100644 plugin_acgimage/classify.go diff --git a/go.mod b/go.mod index 7491df34..ca75303a 100644 --- a/go.mod +++ b/go.mod @@ -3,8 +3,7 @@ module github.com/FloatTech/ZeroBot-Plugin go 1.16 require ( - github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd - github.com/FloatTech/ZeroBot-ACGImage v1.5.5 + github.com/FloatTech/AnimeAPI v1.1.1 github.com/FloatTech/ZeroBot-Plugin-Timer v1.4.2 github.com/StackExchange/wmi v1.2.1 // indirect github.com/golang/protobuf v1.5.2 diff --git a/go.sum b/go.sum index eb9a8334..954791b0 100644 --- a/go.sum +++ b/go.sum @@ -1,15 +1,9 @@ -github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd h1:rvV66DIEqNJMEKwYXDJvw6kpJuGg+Pz/BooewuTBjXs= -github.com/FloatTech/AnimeAPI v0.0.0-20210713044920-63367fe18ccd/go.mod h1:GYrQD70HvBzry1XiZ1tHFNOsOqRkR+ao4XGYZqV4I9c= -github.com/FloatTech/ZeroBot-ACGImage v1.5.5 h1:cmAsXHl99RHJR38vQXL+q/U0BGWg5LyMHxBw5Mf8f1o= -github.com/FloatTech/ZeroBot-ACGImage v1.5.5/go.mod h1:TDGCgGHKjgcnA0akLaEwUcFwL+/ya7p6PZITdJQ1vnQ= -github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4 h1:nRJqY/S7TRlN32MQGIBH3UWfVrpjxpJXCnp42pd2O2Q= -github.com/FloatTech/ZeroBot-Plugin-Timer v1.3.4/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= -github.com/FloatTech/ZeroBot-Plugin-Timer v1.4.1 h1:LVSTyfLlhcJEES16r3gyhN2jd2WJUlQiN193f0DdJ7Q= -github.com/FloatTech/ZeroBot-Plugin-Timer v1.4.1/go.mod h1:NuODdnVhf9AClsJBdYFqnL9sQE7VIRZyZos37J286n0= +github.com/FloatTech/AnimeAPI v1.1.0 h1:X6UMkl6eC8NHHeInt40x0AHb8a3GiQSmE1HigyTG/Qg= +github.com/FloatTech/AnimeAPI v1.1.0/go.mod h1:CC+vF30UGBlcIUxwFOcXIEHoJ4r7c5x2iLQsnUCVdDI= +github.com/FloatTech/AnimeAPI v1.1.1 h1:SPyrVlqRVQHfYOm9x8eGBJWlT+3gj1wtFsbH1bCgkXs= +github.com/FloatTech/AnimeAPI v1.1.1/go.mod h1:CC+vF30UGBlcIUxwFOcXIEHoJ4r7c5x2iLQsnUCVdDI= github.com/FloatTech/ZeroBot-Plugin-Timer v1.4.2 h1:w/JerL8DwdyoxZYB4HRMaHANRV2j+r5XxaQhVB0sjBw= github.com/FloatTech/ZeroBot-Plugin-Timer v1.4.2/go.mod h1:MVOQQ4e6AVGFm993blXXU4Sd6bAsLY2+Zb+/HMrEeEc= -github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.3 h1:mMaBe23yg8mk5U0yb9OS9iX/9hju6Dj+Z+Fty18vIhU= -github.com/FloatTech/Zerobot-ACGImage-Classify v1.3.3/go.mod h1:swPvVKyXu1YFWZ7Kt6R79LgIa16hs4cE1E5LroBB2SQ= github.com/StackExchange/wmi v1.2.1 h1:VIkavFPXSjcnS+O8yTq7NI32k0R5Aj+v39y29VYDOSA= github.com/StackExchange/wmi v1.2.1/go.mod h1:rcmrprowKIVzvc+NUiLncP2uuArMWLCbu9SBzvHz7e8= github.com/antchfx/htmlquery v1.2.3 h1:sP3NFDneHx2stfNXCKbhHFo8XgNjCACnU/4AO5gWz6M= @@ -24,8 +18,6 @@ github.com/dustin/go-humanize v1.0.0/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25Kn github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo= github.com/go-ole/go-ole v1.2.5 h1:t4MGB5xEDZvXI+0rMjjsfBsD7yAgp/s9ZDkL1JndXwY= github.com/go-ole/go-ole v1.2.5/go.mod h1:pprOEPIfldk/42T2oK7lQ4v4JSDwmV0As9GaiUsvbm0= -github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q= -github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q= github.com/golang/groupcache v0.0.0-20200121045136-8c9f03a8e57e h1:1r7pUrabqp18hOBcwBwiTsbnFeTZHV9eER/QT5JVZxY= github.com/golang/groupcache v0.0.0-20200121045136-8c9f03a8e57e/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= github.com/golang/protobuf v1.2.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= @@ -44,8 +36,6 @@ github.com/json-iterator/go v1.1.11 h1:uVUAXhF2To8cbw/3xN3pxj6kk7TYKs98NIrTqPlMW github.com/json-iterator/go v1.1.11/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51 h1:Z9n2FFNUXsshfwJMBgNA0RU6/i7WVaAegv3PtuIHPMs= github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51/go.mod h1:CzGEWj7cYgsdH8dAjBGEr58BoE7ScuLd+fwFZ44+/x8= -github.com/kisielk/errcheck v1.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI2bnpBCr8= -github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck= github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= github.com/mattn/go-isatty v0.0.12 h1:wuysRhFDzyxgEmMf5xjvJ2M9dZoWAXNNr5LSBS7uHXY= github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Kysco4FUpU= @@ -93,27 +83,23 @@ github.com/tklauser/numcpus v0.2.3 h1:nQ0QYpiritP6ViFhrKYsiv6VVxOpum2Gks5GhnJbS/ github.com/tklauser/numcpus v0.2.3/go.mod h1:vpEPS/JC+oZGGQ/My/vJnNsvMDQL6PwOqt8dsCw5j+E= github.com/wdvxdr1123/ZeroBot v1.2.2 h1:BKEy3l80BMrQWpFWaII0AfFMyf9bqrB0TxfWhTdoV58= github.com/wdvxdr1123/ZeroBot v1.2.2/go.mod h1:83nHtG8V5TAxPwH/LCDxLpZk4khIgs29dkr5TBWf7fc= -github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= github.com/yuin/goldmark v1.3.5/go.mod h1:mwnBkeHKe2W/ZEtQ+71ViKU8L12m81fl3OWwC1Zlc8k= golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= -golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/mod v0.4.2 h1:Gz96sIWK3OalVv/I/qNygP42zyoKp3xptRVCWRFEBvo= golang.org/x/mod v0.4.2/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/net v0.0.0-20180906233101-161cd47e91fd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= -golang.org/x/net v0.0.0-20200226121028-0de0cce0169b/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20200421231249-e086a090c8fd/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4 h1:4nGaVu0QrbjT/AK2PRLuQfQuh6DJve+pELhqTdAj3x0= golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4/go.mod h1:p54w0d4576C0XHj96bSt6lcn1PtDYWL6XObtHCRCNQM= golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= -golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= @@ -139,9 +125,7 @@ golang.org/x/text v0.3.6 h1:aRYxNxv6iGQlyVaZmk6ZgYEDa+Jg18DxebPSrd6bg1M= golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= -golang.org/x/tools v0.0.0-20200619180055-7c47624df98f/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= golang.org/x/tools v0.0.0-20201124115921-2c860bdd6e78/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= -golang.org/x/tools v0.0.0-20210106214847-113979e3529a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= golang.org/x/tools v0.1.5 h1:ouewzE6p+/VEB31YYnTbEJdi8pFqKp4P4n85vwo3DHA= golang.org/x/tools v0.1.5/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= @@ -150,7 +134,6 @@ golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8T golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1 h1:go1bK/D/BFZV2I8cIQd1NKEZ+0owSTG1fDTci4IqFcE= golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw= -google.golang.org/protobuf v1.26.0 h1:bxAC2xTBsZGibn2RTntX0oH50xLsqy1OxA9tTL3p/lk= google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc= google.golang.org/protobuf v1.27.1 h1:SnqbnDw1V7RiZcXPx5MEeqPv2s79L9i7BJUlG/+RurQ= google.golang.org/protobuf v1.27.1/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc= diff --git a/main.go b/main.go index 1855ce86..c4ea31b5 100644 --- a/main.go +++ b/main.go @@ -27,7 +27,7 @@ import ( _ "github.com/FloatTech/ZeroBot-Plugin/plugin_diana" // 嘉心糖发病 // 二次元图片 - _ "github.com/FloatTech/ZeroBot-ACGImage" // 随机图片与AI点评 + _ "github.com/FloatTech/ZeroBot-Plugin/plugin_acgimage" // 随机图片与AI点评 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_image_finder" // 关键字搜图 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_lolicon" // lolicon 随机图片 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_saucenao" // 以图搜图 diff --git a/plugin_acgimage/classify.go b/plugin_acgimage/classify.go new file mode 100644 index 00000000..a3f722b8 --- /dev/null +++ b/plugin_acgimage/classify.go @@ -0,0 +1,118 @@ +package acgimage + +import ( + "net/url" + "strconv" + "strings" + + "github.com/FloatTech/AnimeAPI/classify" + "github.com/FloatTech/AnimeAPI/picture" + zero "github.com/wdvxdr1123/ZeroBot" + "github.com/wdvxdr1123/ZeroBot/message" +) + +var ( + lolipxy = "http://sayuri.fumiama.top:62002/dice?class=0&loli=true&r18=true" + // r18有一定保护,一般不会发出图片 + randapi = "&loli=true&r18=true" + msgof = make(map[int64]int64) + datapath = "data/acgimage/" + cachefile = datapath + "cache" + cacheuri = "file:///" + cachefile +) + +func init() { // 插件主体 + zero.OnRegex(`^设置随机图片网址(.*)$`, zero.SuperUserPermission).SetBlock(true).SetPriority(20). + Handle(func(ctx *zero.Ctx) { + url := ctx.State["regex_matched"].([]string)[1] + if !strings.HasPrefix(url, "http") { + ctx.Send("URL非法!") + } else { + randapi = url + } + }) + // 有保护的随机图片 + zero.OnFullMatch("随机图片").SetBlock(true).SetPriority(24). + Handle(func(ctx *zero.Ctx) { + if ctx.Event.GroupID > 0 { + if classify.CanVisit(5) { + go func() { + class, lastvisit, dhash, comment := classify.Classify(randapi, false) + replyClass(ctx, dhash, class, false, lastvisit, comment) + }() + } else { + ctx.Send("你太快啦!") + } + } + }) + // 直接随机图片,无r18保护,后果自负。如果出r18图可尽快通过发送"太涩了"撤回 + zero.OnFullMatch("直接随机", zero.AdminPermission).SetBlock(true).SetPriority(24). + Handle(func(ctx *zero.Ctx) { + if ctx.Event.GroupID > 0 { + if classify.CanVisit(5) { + ctx.Send("请稍后再试哦") + } else if randapi != "" { + var url string + if randapi[0] == '&' { + url = lolipxy + } else { + url = randapi + } + setLastMsg(ctx.Event.GroupID, ctx.Send(message.Image(url).Add("cache", "0"))) + } + } + }) + // 撤回最后的直接随机图片 + zero.OnFullMatch("太涩了").SetBlock(true).SetPriority(24). + Handle(func(ctx *zero.Ctx) { + go cancel(ctx) + }) + // 上传一张图进行评价 + zero.OnKeywordGroup([]string{"评价图片"}, picture.CmdMatch(), picture.MustGiven()).SetBlock(true).SetPriority(24). + Handle(func(ctx *zero.Ctx) { + if ctx.Event.GroupID > 0 { + ctx.Send("少女祈祷中...") + for _, url := range ctx.State["image_url"].([]string) { + go func(target string) { + class, lastvisit, dhash, comment := classify.Classify(target, true) + replyClass(ctx, dhash, class, true, lastvisit, comment) + }(url) + } + } + }) +} + +func setLastMsg(id int64, msg int64) { + msgof[id] = msg +} + +func cancel(ctx *zero.Ctx) { + msg, ok := msgof[ctx.Event.GroupID] + if ok { + ctx.DeleteMessage(msg) + delete(msgof, ctx.Event.GroupID) + } +} + +func replyClass(ctx *zero.Ctx, dhash string, class int, noimg bool, lv int64, comment string) { + img := message.Image(cacheuri + strconv.FormatInt(lv, 10)) + if class > 5 { + if dhash != "" && !noimg { + b14, err3 := url.QueryUnescape(dhash) + if err3 == nil { + ctx.Send(comment + "\n给你点提示哦:" + b14) + ctx.Event.GroupID = 0 + ctx.Send(img) + } + } else { + ctx.Send(comment) + } + } else { + comment := message.Text(comment) + if !noimg { + ctx.SendChain(img, comment) + } else { + ctx.SendChain(message.Reply(ctx.Event.MessageID), comment) + } + } +} diff --git a/plugin_saucenao/searcher.go b/plugin_saucenao/searcher.go index 847ceb5a..99e66a7b 100644 --- a/plugin_saucenao/searcher.go +++ b/plugin_saucenao/searcher.go @@ -5,12 +5,12 @@ import ( "fmt" "strconv" "strings" - "time" zero "github.com/wdvxdr1123/ZeroBot" "github.com/wdvxdr1123/ZeroBot/message" "github.com/FloatTech/AnimeAPI/ascii2d" + "github.com/FloatTech/AnimeAPI/picture" "github.com/FloatTech/AnimeAPI/pixiv" "github.com/FloatTech/AnimeAPI/saucenao" ) @@ -44,49 +44,8 @@ func init() { // 插件主体 ) }) // 以图搜图 - zero.OnKeywordGroup([]string{"以图搜图", "搜索图片", "以图识图"}).SetBlock(true).FirstPriority(). + zero.OnKeywordGroup([]string{"以图搜图", "搜索图片", "以图识图"}, picture.CmdMatch(), picture.MustGiven()).SetBlock(true).FirstPriority(). Handle(func(ctx *zero.Ctx) { - // 匹配命令 - for _, elem := range ctx.Event.Message { - if elem.Type == "text" { - text := strings.ReplaceAll(elem.Data["text"], " ", "") - if text != ctx.State["keyword"].(string) { - return - } - } - } - // 匹配图片 - rule := func() zero.Rule { - return func(ctx *zero.Ctx) bool { - var urls = []string{} - for _, elem := range ctx.Event.Message { - if elem.Type == "image" { - urls = append(urls, elem.Data["url"]) - } - } - if len(urls) > 0 { - ctx.State["image_url"] = urls - return true - } - return false - } - } - // 索取图片 - if !rule()(ctx) { - ctx.SendChain(message.Text("请发送一张图片")) - next := zero.NewFutureEvent("message", 999, false, zero.CheckUser(ctx.Event.UserID), rule()) - recv, cancel := next.Repeat() - select { - case <-time.After(time.Second * 120): - return - case e := <-recv: - cancel() - newCtx := &zero.Ctx{Event: e, State: zero.State{}} - if rule()(newCtx) { - ctx.State["image_url"] = newCtx.State["image_url"] - } - } - } // 开始搜索图片 ctx.Send("少女祈祷中......") for _, pic := range ctx.State["image_url"].([]string) { From b767f5500aaafdfc4bdc2a97f6df3946665b95c3 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 23:27:55 +0800 Subject: [PATCH 62/79] =?UTF-8?q?=F0=9F=8E=A8=20=E4=BC=98=E5=8C=96?= =?UTF-8?q?=E4=BB=A3=E7=A0=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_acgimage/classify.go | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/plugin_acgimage/classify.go b/plugin_acgimage/classify.go index a3f722b8..ac345559 100644 --- a/plugin_acgimage/classify.go +++ b/plugin_acgimage/classify.go @@ -11,17 +11,21 @@ import ( "github.com/wdvxdr1123/ZeroBot/message" ) +const ( + datapath = "data/acgimage/" + cacheuri = "file:///" + datapath + "cache" + lolipxy = "http://sayuri.fumiama.top:62002/dice?class=0&loli=true&r18=true" +) + var ( - lolipxy = "http://sayuri.fumiama.top:62002/dice?class=0&loli=true&r18=true" // r18有一定保护,一般不会发出图片 - randapi = "&loli=true&r18=true" - msgof = make(map[int64]int64) - datapath = "data/acgimage/" - cachefile = datapath + "cache" - cacheuri = "file:///" + cachefile + randapi = "&loli=true&r18=true" + msgof = make(map[int64]int64) ) func init() { // 插件主体 + // 初始化 classify + classify.Init(datapath) zero.OnRegex(`^设置随机图片网址(.*)$`, zero.SuperUserPermission).SetBlock(true).SetPriority(20). Handle(func(ctx *zero.Ctx) { url := ctx.State["regex_matched"].([]string)[1] From 173626a63813cbc5b51d7e73645572af0d3ff126 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 23:38:09 +0800 Subject: [PATCH 63/79] =?UTF-8?q?=E2=9C=8F=EF=B8=8F=20=E4=BF=AE=E6=94=B9?= =?UTF-8?q?=E7=89=88=E6=9C=AC=E5=8F=B7=E4=B8=BAv1.1.0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- main.go | 35 +++++++++++++++++------------------ 1 file changed, 17 insertions(+), 18 deletions(-) diff --git a/main.go b/main.go index c4ea31b5..6903eabe 100644 --- a/main.go +++ b/main.go @@ -17,10 +17,10 @@ import ( _ "github.com/FloatTech/ZeroBot-Plugin/plugin_runcode" // 在线运行代码 // 娱乐类 - _ "github.com/FloatTech/ZeroBot-Plugin/plugin_ai_false" // 服务器监控 - _ "github.com/FloatTech/ZeroBot-Plugin/plugin_minecraft" - _ "github.com/FloatTech/ZeroBot-Plugin/plugin_music" // 点歌 - _ "github.com/FloatTech/ZeroBot-Plugin/plugin_shindan" // 测定 + _ "github.com/FloatTech/ZeroBot-Plugin/plugin_ai_false" // 服务器监控 + _ "github.com/FloatTech/ZeroBot-Plugin/plugin_minecraft" // MCSManager + _ "github.com/FloatTech/ZeroBot-Plugin/plugin_music" // 点歌 + _ "github.com/FloatTech/ZeroBot-Plugin/plugin_shindan" // 测定 // b站相关 _ "github.com/FloatTech/ZeroBot-Plugin/plugin_bilibili" // 查询b站用户信息 @@ -34,20 +34,21 @@ import ( _ "github.com/FloatTech/ZeroBot-Plugin/plugin_setutime" // 来份涩图 // 以下为内置依赖,勿动 - zero "github.com/wdvxdr1123/ZeroBot" - "github.com/wdvxdr1123/ZeroBot/driver" - "github.com/wdvxdr1123/ZeroBot/message" - log "github.com/sirupsen/logrus" easy "github.com/t-tomalak/logrus-easy-formatter" + zero "github.com/wdvxdr1123/ZeroBot" + "github.com/wdvxdr1123/ZeroBot/driver" ) -var content = []string{ - "* OneBot + ZeroBot + Golang ", - "* Version 1.0.4 - 2021-07-14 14:09:58.581489207 +0800 CST", - "* Copyright © 2020 - 2021 Kanri, DawnNights, Fumiama, Suika", - "* Project: https://github.com/FloatTech/ZeroBot-Plugin", -} +var ( + contents = []string{ + "* OneBot + ZeroBot + Golang ", + "* Version 1.1.0 - 2021-08-06 23:36:29 +0800 CST", + "* Copyright © 2020 - 2021 Kanri, DawnNights, Fumiama, Suika", + "* Project: https://github.com/FloatTech/ZeroBot-Plugin", + } + banner = strings.Join(contents, "\n") +) func init() { log.SetFormatter(&easy.Formatter{ @@ -60,7 +61,7 @@ func init() { func main() { fmt.Print( "======================[ZeroBot-Plugin]======================", - "\n", strings.Join(content, "\n"), "\n", + "\n", banner, "\n", "============================================================\n", ) // 启动打印 zero.Run(zero.Config{ @@ -84,9 +85,7 @@ func main() { // 帮助 zero.OnFullMatchGroup([]string{"help", "/help", ".help", "菜单", "帮助"}, zero.OnlyToMe).SetBlock(true).SetPriority(999). Handle(func(ctx *zero.Ctx) { - ctx.SendChain( - message.Text(strings.Join(content, "\n")), - ) + ctx.Send(banner) }) select {} } From f4375cb6c46a7139d0be1306485cd25f471dfae1 Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 23:41:28 +0800 Subject: [PATCH 64/79] =?UTF-8?q?=E2=9C=8F=EF=B8=8F=20=E5=A2=9E=E5=8A=A0cl?= =?UTF-8?q?assify=E5=8C=85=E8=AF=B4=E6=98=8E?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_acgimage/classify.go | 1 + 1 file changed, 1 insertion(+) diff --git a/plugin_acgimage/classify.go b/plugin_acgimage/classify.go index ac345559..ae1902dd 100644 --- a/plugin_acgimage/classify.go +++ b/plugin_acgimage/classify.go @@ -1,3 +1,4 @@ +// Package acgimage 随机图片与AI点评 package acgimage import ( From 16bef14df49ca2bc19b7a25a5da9f1aeba1fa76b Mon Sep 17 00:00:00 2001 From: fumiama Date: Fri, 6 Aug 2021 23:50:58 +0800 Subject: [PATCH 65/79] =?UTF-8?q?=E2=9C=8F=EF=B8=8F=20=E4=BD=BF=E7=94=A8?= =?UTF-8?q?=E7=BB=9D=E5=AF=B9=E8=B7=AF=E5=BE=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_acgimage/classify.go | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/plugin_acgimage/classify.go b/plugin_acgimage/classify.go index ae1902dd..a86fdbf3 100644 --- a/plugin_acgimage/classify.go +++ b/plugin_acgimage/classify.go @@ -3,6 +3,7 @@ package acgimage import ( "net/url" + "os" "strconv" "strings" @@ -13,12 +14,13 @@ import ( ) const ( - datapath = "data/acgimage/" - cacheuri = "file:///" + datapath + "cache" - lolipxy = "http://sayuri.fumiama.top:62002/dice?class=0&loli=true&r18=true" + lolipxy = "http://sayuri.fumiama.top:62002/dice?class=0&loli=true&r18=true" ) var ( + botpath, _ = os.Getwd() + datapath = botpath + "/data/acgimage/" + cacheuri = "file:///" + datapath + "cache" // r18有一定保护,一般不会发出图片 randapi = "&loli=true&r18=true" msgof = make(map[int64]int64) From 421c2028cafd9e6b492c6905ea64e728f4bc0d6f Mon Sep 17 00:00:00 2001 From: fumiama Date: Sat, 7 Aug 2021 00:00:11 +0800 Subject: [PATCH 66/79] =?UTF-8?q?=E2=9C=A8=20=E5=8D=87=E7=BA=A7AnimeAPI?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- go.mod | 2 +- go.sum | 2 ++ 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/go.mod b/go.mod index ca75303a..d3dbf0f7 100644 --- a/go.mod +++ b/go.mod @@ -3,7 +3,7 @@ module github.com/FloatTech/ZeroBot-Plugin go 1.16 require ( - github.com/FloatTech/AnimeAPI v1.1.1 + github.com/FloatTech/AnimeAPI v1.1.2 github.com/FloatTech/ZeroBot-Plugin-Timer v1.4.2 github.com/StackExchange/wmi v1.2.1 // indirect github.com/golang/protobuf v1.5.2 diff --git a/go.sum b/go.sum index 954791b0..0ad5ea4e 100644 --- a/go.sum +++ b/go.sum @@ -2,6 +2,8 @@ github.com/FloatTech/AnimeAPI v1.1.0 h1:X6UMkl6eC8NHHeInt40x0AHb8a3GiQSmE1HigyTG github.com/FloatTech/AnimeAPI v1.1.0/go.mod h1:CC+vF30UGBlcIUxwFOcXIEHoJ4r7c5x2iLQsnUCVdDI= github.com/FloatTech/AnimeAPI v1.1.1 h1:SPyrVlqRVQHfYOm9x8eGBJWlT+3gj1wtFsbH1bCgkXs= github.com/FloatTech/AnimeAPI v1.1.1/go.mod h1:CC+vF30UGBlcIUxwFOcXIEHoJ4r7c5x2iLQsnUCVdDI= +github.com/FloatTech/AnimeAPI v1.1.2 h1:u+aVY1HlRi6jCvOQ9dePNGtCv71ESt79SG1Y4JZNx38= +github.com/FloatTech/AnimeAPI v1.1.2/go.mod h1:CC+vF30UGBlcIUxwFOcXIEHoJ4r7c5x2iLQsnUCVdDI= github.com/FloatTech/ZeroBot-Plugin-Timer v1.4.2 h1:w/JerL8DwdyoxZYB4HRMaHANRV2j+r5XxaQhVB0sjBw= github.com/FloatTech/ZeroBot-Plugin-Timer v1.4.2/go.mod h1:MVOQQ4e6AVGFm993blXXU4Sd6bAsLY2+Zb+/HMrEeEc= github.com/StackExchange/wmi v1.2.1 h1:VIkavFPXSjcnS+O8yTq7NI32k0R5Aj+v39y29VYDOSA= From 370933df1ddfe78608a78026b9a4d405fb8b437d Mon Sep 17 00:00:00 2001 From: fumiama Date: Sat, 7 Aug 2021 00:03:50 +0800 Subject: [PATCH 67/79] =?UTF-8?q?=E2=9C=8F=EF=B8=8F=20=E4=BF=AE=E6=AD=A3?= =?UTF-8?q?=E7=9B=B4=E6=8E=A5=E9=9A=8F=E6=9C=BA?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_acgimage/classify.go | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/plugin_acgimage/classify.go b/plugin_acgimage/classify.go index a86fdbf3..2a590d81 100644 --- a/plugin_acgimage/classify.go +++ b/plugin_acgimage/classify.go @@ -24,6 +24,7 @@ var ( // r18有一定保护,一般不会发出图片 randapi = "&loli=true&r18=true" msgof = make(map[int64]int64) + block = false ) func init() { // 插件主体 @@ -56,9 +57,10 @@ func init() { // 插件主体 zero.OnFullMatch("直接随机", zero.AdminPermission).SetBlock(true).SetPriority(24). Handle(func(ctx *zero.Ctx) { if ctx.Event.GroupID > 0 { - if classify.CanVisit(5) { + if block { ctx.Send("请稍后再试哦") } else if randapi != "" { + block = true var url string if randapi[0] == '&' { url = lolipxy @@ -66,6 +68,7 @@ func init() { // 插件主体 url = randapi } setLastMsg(ctx.Event.GroupID, ctx.Send(message.Image(url).Add("cache", "0"))) + block = false } } }) From 867e2143f2d1b3322ab101afc37c7bcece4c68b1 Mon Sep 17 00:00:00 2001 From: fumiama Date: Sat, 7 Aug 2021 01:11:10 +0800 Subject: [PATCH 68/79] =?UTF-8?q?=E2=9C=A8=20=E6=9B=B4=E6=96=B0=E7=BC=96?= =?UTF-8?q?=E8=AF=91?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/linux.yml | 42 ---------------------- .github/workflows/push.yml | 54 ++++++++++++++++++++++++++++ .github/workflows/release.yml | 66 +++++++++++++++++++++++++++++++++++ .github/workflows/windows.yml | 41 ---------------------- README.md | 6 ++-- 5 files changed, 123 insertions(+), 86 deletions(-) delete mode 100644 .github/workflows/linux.yml create mode 100644 .github/workflows/push.yml create mode 100644 .github/workflows/release.yml delete mode 100644 .github/workflows/windows.yml diff --git a/.github/workflows/linux.yml b/.github/workflows/linux.yml deleted file mode 100644 index 950bd00d..00000000 --- a/.github/workflows/linux.yml +++ /dev/null @@ -1,42 +0,0 @@ -name: Compile ZeroBot-Plugin-linux -on: - push: - branches: - - master - -env: - GITHUB_TOKEN: ${{ github.token }} - -jobs: - my-job: - name: Build ZeroBot-Plugin-linux 🚀 - runs-on: ubuntu-latest - steps: - - - name: Set up Go - uses: actions/setup-go@v2 - with: - go-version: 1.16 - - - name: Check out code into the Go module directory - uses: actions/checkout@v2 - - - name: Cache Go - id: cache - uses: actions/cache@v2 - with: - # A list of files, directories, and wildcard patterns to cache and restore - path: ~/go/pkg/mod - key: ${{ runner.os }}-build-${{ hashFiles('**/go.sum') }} - - - name: Tidy Go modules - run: go mod tidy - - - name: Build - run: go build -ldflags="-s -w" -o artifacts/ZeroBot-Plugin-linux - - - name: Upload Build Artifact - uses: actions/upload-artifact@v2 - with: - name: ZeroBot-Plugin-linux - path: ./artifacts diff --git a/.github/workflows/push.yml b/.github/workflows/push.yml new file mode 100644 index 00000000..1e255556 --- /dev/null +++ b/.github/workflows/push.yml @@ -0,0 +1,54 @@ +name: 最新版 +on: + push: + branches: + - master + +env: + GITHUB_TOKEN: ${{ github.token }} + +jobs: + my-job: + name: Build ZeroBot-Plugin on Push 🚀 + runs-on: ubuntu-latest + steps: + + - name: Set up Go + uses: actions/setup-go@v2 + with: + go-version: 1.16 + + - name: Check out code into the Go module directory + uses: actions/checkout@v2 + + - name: Cache Go + id: cache + uses: actions/cache@v2 + with: + # A list of files, directories, and wildcard patterns to cache and restore + path: ~/go/pkg/mod + key: ${{ runner.os }}-build-${{ hashFiles('**/go.sum') }} + + - name: Tidy Go modules + run: go mod tidy + + - name: Build linux-x64 + run: CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-x64 + - name: Build linux-x86 + run: CGO_ENABLED=0 GOOS=linux GOARCH=386 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-x86 + - name: Build windows-x64 + run: CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-windows-x64.exe + - name: Build windows-x86 + run: CGO_ENABLED=0 GOOS=windows GOARCH=386 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-windows-x86.exe + - name: Build armv7 + run: CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=7 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-armv6 + - name: Build armv6 + run: CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=6 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-armv6 + - name: Build mips + run: GOOS=linux GOARCH=mips GOMIPS=softfloat CGO_ENABLED=0 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-mips + + - name: Upload Build Artifact + uses: actions/upload-artifact@v2 + with: + name: zerobot-plugin-* + path: ./artifacts diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml new file mode 100644 index 00000000..e2de2135 --- /dev/null +++ b/.github/workflows/release.yml @@ -0,0 +1,66 @@ +name: 稳定版 +on: + push: + tags: + - v* + +env: + GITHUB_TOKEN: ${{ github.token }} + +jobs: + my-job: + name: Build ZeroBot-Plugin on Push Tag 🚀 + runs-on: ubuntu-latest + steps: + + - name: Set up Go + uses: actions/setup-go@v2 + with: + go-version: 1.16 + + - name: Check out code into the Go module directory + uses: actions/checkout@v2 + + - name: Cache Go + id: cache + uses: actions/cache@v2 + with: + # A list of files, directories, and wildcard patterns to cache and restore + path: ~/go/pkg/mod + key: ${{ runner.os }}-build-${{ hashFiles('**/go.sum') }} + + - name: Tidy Go modules + run: go mod tidy + + - name: Build linux-x64 + run: CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-x64 + - name: Build linux-x86 + run: CGO_ENABLED=0 GOOS=linux GOARCH=386 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-x86 + - name: Build windows-x64 + run: CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-windows-x64.exe + - name: Build windows-x86 + run: CGO_ENABLED=0 GOOS=windows GOARCH=386 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-windows-x86.exe + - name: Build armv7 + run: CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=7 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-armv6 + - name: Build armv6 + run: CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=6 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-armv6 + - name: Build mips + run: GOOS=linux GOARCH=mips GOMIPS=softfloat CGO_ENABLED=0 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-mips + + - name: Create Release + id: create_release + uses: actions/create-release@v1 + with: + tag_name: ${{ github.ref }} + release_name: Release ${{ github.ref }} + draft: false + prerelease: false + + - name: Upload Release Asset + id: upload-release-asset + uses: actions/upload-release-asset@v1 + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps + asset_path: ./artifacts + asset_name: zerobot-plugin-* + asset_content_type: application/octet-stream \ No newline at end of file diff --git a/.github/workflows/windows.yml b/.github/workflows/windows.yml deleted file mode 100644 index 14d17f28..00000000 --- a/.github/workflows/windows.yml +++ /dev/null @@ -1,41 +0,0 @@ -name: Compile ZeroBot-Plugin-windows -on: - push: - branches: - - master - -env: - GITHUB_TOKEN: ${{ github.token }} - -jobs: - my-job: - name: Build ZeroBot-Plugin-windows 🚀 - runs-on: windows-latest - steps: - - - name: Set up Go - uses: actions/setup-go@v2 - with: - go-version: 1.16 - - - name: Check out code into the Go module directory - uses: actions/checkout@v2 - - - name: Cache Go - id: cache - uses: actions/cache@v2 - with: - path: ~/go/pkg/mod - key: ${{ runner.os }}-build-${{ hashFiles('**/go.sum') }} - - - name: Tidy Go modules - run: go mod tidy - - - name: Build - run: go build -ldflags="-s -w" -o artifacts/ZeroBot-Plugin-windows.exe - - - name: Upload Build Artifact - uses: actions/upload-artifact@v2 - with: - name: ZeroBot-Plugin-windows.exe - path: ./artifacts diff --git a/README.md b/README.md index d20cf5d7..579c2c73 100644 --- a/README.md +++ b/README.md @@ -16,9 +16,6 @@ [![License](https://img.shields.io/github/license/Yiwen-Chan/OneBot-YaYa.svg?style=flat-square&logo=gnu)](https://raw.githubusercontent.com/FloatTech/ZeroBot-Plugin/master/LICENSE) [![qq group](https://img.shields.io/badge/group-1048452984-red?style=flat-square&logo=tencent-qq)](https://jq.qq.com/?_wv=1027&k=QMb7x1mM) -[![Compile ZeroBot-Plugin-linux](https://github.com/FloatTech/ZeroBot-Plugin/actions/workflows/linux.yml/badge.svg?branch=master)](https://github.com/FloatTech/ZeroBot-Plugin/actions/workflows/linux.yml) -[![Compile ZeroBot-Plugin-windows](https://github.com/FloatTech/ZeroBot-Plugin/actions/workflows/windows.yml/badge.svg?branch=master)](https://github.com/FloatTech/ZeroBot-Plugin/actions/workflows/windows.yml) - @@ -117,6 +114,9 @@ | [yyuueexxiinngg/cqhttp-mirai](https://github.com/yyuueexxiinngg/cqhttp-mirai) | [Mirai](https://github.com/mamoe/mirai) | yyuueexxiinngg | | | [takayama-lily/onebot](https://github.com/takayama-lily/onebot) | [OICQ](https://github.com/takayama-lily/oicq) | takayama | | +### 使用稳定版 +可以前往[Release](https://github.com/FloatTech/ZeroBot-Plugin/releases)页面下载对应系统的稳定版,默认开启全部插件。 + ### 本地运行 1. 下载安装 [Go](https://studygolang.com/dl/golang/go1.16.2.windows-amd64.msi) 环境 2. 下载本项目[压缩包](https://github.com/Yiwen-Chan/ZeroBot-Plugin/archive/master.zip),本地解压 From 5af995940816ecb7b5c866dc049e27bf6ff99fd3 Mon Sep 17 00:00:00 2001 From: fumiama Date: Sat, 7 Aug 2021 01:20:09 +0800 Subject: [PATCH 69/79] =?UTF-8?q?=E2=9C=A8=20=E6=9B=B4=E6=96=B0=E7=BC=96?= =?UTF-8?q?=E8=AF=91?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/push.yml | 6 ++---- .github/workflows/release.yml | 6 ++---- 2 files changed, 4 insertions(+), 8 deletions(-) diff --git a/.github/workflows/push.yml b/.github/workflows/push.yml index 1e255556..16623f35 100644 --- a/.github/workflows/push.yml +++ b/.github/workflows/push.yml @@ -40,12 +40,10 @@ jobs: run: CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-windows-x64.exe - name: Build windows-x86 run: CGO_ENABLED=0 GOOS=windows GOARCH=386 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-windows-x86.exe - - name: Build armv7 - run: CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=7 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-armv6 + - name: Build arm64 + run: CGO_ENABLED=0 GOOS=linux GOARCH=arm64 GOARM=7 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-arm64 - name: Build armv6 run: CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=6 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-armv6 - - name: Build mips - run: GOOS=linux GOARCH=mips GOMIPS=softfloat CGO_ENABLED=0 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-mips - name: Upload Build Artifact uses: actions/upload-artifact@v2 diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index e2de2135..d164ecbf 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -40,12 +40,10 @@ jobs: run: CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-windows-x64.exe - name: Build windows-x86 run: CGO_ENABLED=0 GOOS=windows GOARCH=386 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-windows-x86.exe - - name: Build armv7 - run: CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=7 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-armv6 + - name: Build arm64 + run: CGO_ENABLED=0 GOOS=linux GOARCH=arm64 GOARM=7 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-arm64 - name: Build armv6 run: CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=6 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-armv6 - - name: Build mips - run: GOOS=linux GOARCH=mips GOMIPS=softfloat CGO_ENABLED=0 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-mips - name: Create Release id: create_release From 2900b4b616f5ba3741ccc2e41a95eafa939b29c7 Mon Sep 17 00:00:00 2001 From: fumiama Date: Sat, 7 Aug 2021 01:22:47 +0800 Subject: [PATCH 70/79] =?UTF-8?q?=E2=9C=A8=20=E6=9B=B4=E6=96=B0=E7=BC=96?= =?UTF-8?q?=E8=AF=91?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../workflows/{suggester.yml => pulllint.yml} | 2 +- .../workflows/{golint.yml => pushlint.yml} | 0 .github/workflows/release.yml | 30 +++++++++---------- 3 files changed, 16 insertions(+), 16 deletions(-) rename .github/workflows/{suggester.yml => pulllint.yml} (98%) rename .github/workflows/{golint.yml => pushlint.yml} (100%) diff --git a/.github/workflows/suggester.yml b/.github/workflows/pulllint.yml similarity index 98% rename from .github/workflows/suggester.yml rename to .github/workflows/pulllint.yml index a0c6b202..72731fdc 100644 --- a/.github/workflows/suggester.yml +++ b/.github/workflows/pulllint.yml @@ -1,4 +1,4 @@ -name: Lint +name: PullLint on: [pull_request] jobs: golangci: diff --git a/.github/workflows/golint.yml b/.github/workflows/pushlint.yml similarity index 100% rename from .github/workflows/golint.yml rename to .github/workflows/pushlint.yml diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index d164ecbf..d411c2e6 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -46,19 +46,19 @@ jobs: run: CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=6 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-armv6 - name: Create Release - id: create_release - uses: actions/create-release@v1 - with: - tag_name: ${{ github.ref }} - release_name: Release ${{ github.ref }} - draft: false - prerelease: false + id: create_release + uses: actions/create-release@v1 + with: + tag_name: ${{ github.ref }} + release_name: Release ${{ github.ref }} + draft: false + prerelease: false - - name: Upload Release Asset - id: upload-release-asset - uses: actions/upload-release-asset@v1 - with: - upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps - asset_path: ./artifacts - asset_name: zerobot-plugin-* - asset_content_type: application/octet-stream \ No newline at end of file + - name: Upload Release Asset + id: upload-release-asset + uses: actions/upload-release-asset@v1 + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps + asset_path: ./artifacts + asset_name: zerobot-plugin-* + asset_content_type: application/octet-stream \ No newline at end of file From 93ee86520b37c0ad186aad965fccf297cdfeed5d Mon Sep 17 00:00:00 2001 From: fumiama Date: Sat, 7 Aug 2021 01:26:33 +0800 Subject: [PATCH 71/79] =?UTF-8?q?=E2=9C=A8=20=E6=9B=B4=E6=96=B0=E7=BC=96?= =?UTF-8?q?=E8=AF=91?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/latest.yml | 52 ++++++++++++++ .github/workflows/{pulllint.yml => pull.yml} | 0 .github/workflows/push.yml | 71 +++++++------------- .github/workflows/pushlint.yml | 31 --------- .github/workflows/release.yml | 2 +- 5 files changed, 78 insertions(+), 78 deletions(-) create mode 100644 .github/workflows/latest.yml rename .github/workflows/{pulllint.yml => pull.yml} (100%) delete mode 100644 .github/workflows/pushlint.yml diff --git a/.github/workflows/latest.yml b/.github/workflows/latest.yml new file mode 100644 index 00000000..740b3399 --- /dev/null +++ b/.github/workflows/latest.yml @@ -0,0 +1,52 @@ +name: 最新版 +on: + push: + branches: + - master + +env: + GITHUB_TOKEN: ${{ github.token }} + +jobs: + my-job: + name: Build ZeroBot-Plugin on Push 🚀 + runs-on: ubuntu-latest + steps: + + - name: Set up Go + uses: actions/setup-go@v2 + with: + go-version: 1.16 + + - name: Check out code into the Go module directory + uses: actions/checkout@v2 + + - name: Cache Go + id: cache + uses: actions/cache@v2 + with: + # A list of files, directories, and wildcard patterns to cache and restore + path: ~/go/pkg/mod + key: ${{ runner.os }}-build-${{ hashFiles('**/go.sum') }} + + - name: Tidy Go modules + run: go mod tidy + + - name: Build linux-x64 + run: CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-x64 + - name: Build linux-x86 + run: CGO_ENABLED=0 GOOS=linux GOARCH=386 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-x86 + - name: Build windows-x64 + run: CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-windows-x64.exe + - name: Build windows-x86 + run: CGO_ENABLED=0 GOOS=windows GOARCH=386 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-windows-x86.exe + - name: Build arm64 + run: CGO_ENABLED=0 GOOS=linux GOARCH=arm64 GOARM=7 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-arm64 + - name: Build armv6 + run: CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=6 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-armv6 + + - name: Upload Build Artifact + uses: actions/upload-artifact@v2 + with: + name: zerobot-plugin + path: ./artifacts diff --git a/.github/workflows/pulllint.yml b/.github/workflows/pull.yml similarity index 100% rename from .github/workflows/pulllint.yml rename to .github/workflows/pull.yml diff --git a/.github/workflows/push.yml b/.github/workflows/push.yml index 16623f35..c07742d4 100644 --- a/.github/workflows/push.yml +++ b/.github/workflows/push.yml @@ -1,52 +1,31 @@ -name: 最新版 -on: - push: - branches: - - master - -env: - GITHUB_TOKEN: ${{ github.token }} - +name: PushLint +on: [push] jobs: - my-job: - name: Build ZeroBot-Plugin on Push 🚀 + golangci: + name: lint runs-on: ubuntu-latest steps: + - uses: actions/checkout@v2 + - name: golangci-lint + uses: golangci/golangci-lint-action@v2 + with: + # Optional: version of golangci-lint to use in form of v1.2 or v1.2.3 or `latest` to use the latest version + version: latest - - name: Set up Go - uses: actions/setup-go@v2 - with: - go-version: 1.16 + # Optional: working directory, useful for monorepos + # working-directory: somedir - - name: Check out code into the Go module directory - uses: actions/checkout@v2 - - - name: Cache Go - id: cache - uses: actions/cache@v2 - with: - # A list of files, directories, and wildcard patterns to cache and restore - path: ~/go/pkg/mod - key: ${{ runner.os }}-build-${{ hashFiles('**/go.sum') }} + # Optional: golangci-lint command line arguments. + # args: --issues-exit-code=0 - - name: Tidy Go modules - run: go mod tidy - - - name: Build linux-x64 - run: CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-x64 - - name: Build linux-x86 - run: CGO_ENABLED=0 GOOS=linux GOARCH=386 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-x86 - - name: Build windows-x64 - run: CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-windows-x64.exe - - name: Build windows-x86 - run: CGO_ENABLED=0 GOOS=windows GOARCH=386 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-windows-x86.exe - - name: Build arm64 - run: CGO_ENABLED=0 GOOS=linux GOARCH=arm64 GOARM=7 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-arm64 - - name: Build armv6 - run: CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=6 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-armv6 - - - name: Upload Build Artifact - uses: actions/upload-artifact@v2 - with: - name: zerobot-plugin-* - path: ./artifacts + # Optional: show only new issues if it's a pull request. The default value is `false`. + # only-new-issues: true + + # Optional: if set to true then the action will use pre-installed Go. + # skip-go-installation: true + + # Optional: if set to true then the action don't cache or restore ~/go/pkg. + # skip-pkg-cache: true + + # Optional: if set to true then the action don't cache or restore ~/.cache/go-build. + # skip-build-cache: true diff --git a/.github/workflows/pushlint.yml b/.github/workflows/pushlint.yml deleted file mode 100644 index c07742d4..00000000 --- a/.github/workflows/pushlint.yml +++ /dev/null @@ -1,31 +0,0 @@ -name: PushLint -on: [push] -jobs: - golangci: - name: lint - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - name: golangci-lint - uses: golangci/golangci-lint-action@v2 - with: - # Optional: version of golangci-lint to use in form of v1.2 or v1.2.3 or `latest` to use the latest version - version: latest - - # Optional: working directory, useful for monorepos - # working-directory: somedir - - # Optional: golangci-lint command line arguments. - # args: --issues-exit-code=0 - - # Optional: show only new issues if it's a pull request. The default value is `false`. - # only-new-issues: true - - # Optional: if set to true then the action will use pre-installed Go. - # skip-go-installation: true - - # Optional: if set to true then the action don't cache or restore ~/go/pkg. - # skip-pkg-cache: true - - # Optional: if set to true then the action don't cache or restore ~/.cache/go-build. - # skip-build-cache: true diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index d411c2e6..97aff45e 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -60,5 +60,5 @@ jobs: with: upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps asset_path: ./artifacts - asset_name: zerobot-plugin-* + asset_name: zerobot-plugin asset_content_type: application/octet-stream \ No newline at end of file From 81ccf8e4f59afdbc4385b6a5f89a1e3c3eb026cf Mon Sep 17 00:00:00 2001 From: fumiama Date: Sat, 7 Aug 2021 01:34:38 +0800 Subject: [PATCH 72/79] =?UTF-8?q?=E6=B5=8B=E8=AF=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/latest.yml | 12 +----------- 1 file changed, 1 insertion(+), 11 deletions(-) diff --git a/.github/workflows/latest.yml b/.github/workflows/latest.yml index 740b3399..e8f8fd65 100644 --- a/.github/workflows/latest.yml +++ b/.github/workflows/latest.yml @@ -34,19 +34,9 @@ jobs: - name: Build linux-x64 run: CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-x64 - - name: Build linux-x86 - run: CGO_ENABLED=0 GOOS=linux GOARCH=386 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-x86 - - name: Build windows-x64 - run: CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-windows-x64.exe - - name: Build windows-x86 - run: CGO_ENABLED=0 GOOS=windows GOARCH=386 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-windows-x86.exe - - name: Build arm64 - run: CGO_ENABLED=0 GOOS=linux GOARCH=arm64 GOARM=7 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-arm64 - - name: Build armv6 - run: CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=6 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-armv6 - name: Upload Build Artifact uses: actions/upload-artifact@v2 with: name: zerobot-plugin - path: ./artifacts + path: ./artifacts/zerobot-plugin-* \ No newline at end of file From 28b9d0b18f1cc44d2b18fb3a7005ddfa798d24f5 Mon Sep 17 00:00:00 2001 From: fumiama Date: Sat, 7 Aug 2021 01:40:06 +0800 Subject: [PATCH 73/79] =?UTF-8?q?=E2=9C=A8=20=E6=9B=B4=E6=96=B0=E7=BC=96?= =?UTF-8?q?=E8=AF=91?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/latest.yml | 42 +++++++++++++++++++++++++++--- .github/workflows/release.yml | 49 ++++++++++++++++++++++++++++++++--- 2 files changed, 84 insertions(+), 7 deletions(-) diff --git a/.github/workflows/latest.yml b/.github/workflows/latest.yml index e8f8fd65..fa9334d4 100644 --- a/.github/workflows/latest.yml +++ b/.github/workflows/latest.yml @@ -34,9 +34,45 @@ jobs: - name: Build linux-x64 run: CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-x64 + - name: Build linux-x86 + run: CGO_ENABLED=0 GOOS=linux GOARCH=386 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-x86 + - name: Build windows-x64 + run: CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-windows-x64.exe + - name: Build windows-x86 + run: CGO_ENABLED=0 GOOS=windows GOARCH=386 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-windows-x86.exe + - name: Build arm64 + run: CGO_ENABLED=0 GOOS=linux GOARCH=arm64 GOARM=7 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-arm64 + - name: Build armv6 + run: CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=6 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-armv6 - - name: Upload Build Artifact + - name: Upload Build Artifact Linux x64 uses: actions/upload-artifact@v2 with: - name: zerobot-plugin - path: ./artifacts/zerobot-plugin-* \ No newline at end of file + name: zerobot-plugin-linux-x64 + path: ./artifacts/zerobot-plugin-linux-x64 + - name: Upload Build Artifact Linux x86 + uses: actions/upload-artifact@v2 + with: + name: zerobot-plugin-linux-x86 + path: ./artifacts/zerobot-plugin-linux-x86 + - name: Upload Build Artifact Windows x64 + uses: actions/upload-artifact@v2 + with: + name: zerobot-plugin-windows-x64.exe + path: ./artifacts/zerobot-plugin-windows-x64.exe + - name: Upload Build Artifact Windows x86 + uses: actions/upload-artifact@v2 + with: + name: zerobot-plugin-windows-x86.exe + path: ./artifacts/zerobot-plugin-windows-x86.exe + - name: Upload Build Artifact Linux arm64 + uses: actions/upload-artifact@v2 + with: + name: zerobot-plugin-linux-arm64 + path: ./artifacts/zerobot-plugin-linux-arm64 + - name: Upload Build Artifact Linux armv6 + uses: actions/upload-artifact@v2 + with: + name: zerobot-plugin-linux-armv6 + path: ./artifacts/zerobot-plugin-linux-armv6 + diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 97aff45e..1c038243 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -54,11 +54,52 @@ jobs: draft: false prerelease: false - - name: Upload Release Asset + - name: Upload Release Asset Linux x64 id: upload-release-asset uses: actions/upload-release-asset@v1 with: upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps - asset_path: ./artifacts - asset_name: zerobot-plugin - asset_content_type: application/octet-stream \ No newline at end of file + asset_path: ./artifacts/zerobot-plugin-linux-x64 + asset_name: zerobot-plugin-linux-x64 + asset_content_type: application/octet-stream + - name: Upload Release Asset Linux x86 + id: upload-release-asset + uses: actions/upload-release-asset@v1 + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps + asset_path: ./artifacts/zerobot-plugin-linux-x86 + asset_name: zerobot-plugin-linux-x86 + asset_content_type: application/octet-stream + - name: Upload Release Asset Windows x64 + id: upload-release-asset + uses: actions/upload-release-asset@v1 + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps + asset_path: ./artifacts/zerobot-plugin-windows-x64.exe + asset_name: zerobot-plugin-windows-x64.exe + asset_content_type: application/octet-stream + - name: Upload Release Asset Windows x86 + id: upload-release-asset + uses: actions/upload-release-asset@v1 + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps + asset_path: ./artifacts/zerobot-plugin-windows-x86.exe + asset_name: zerobot-plugin-windows-x86.exe + asset_content_type: application/octet-stream + - name: Upload Release Asset ARM64 + id: upload-release-asset + uses: actions/upload-release-asset@v1 + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps + asset_path: ./artifacts/zerobot-plugin-linux-arm64 + asset_name: zerobot-plugin-linux-arm64 + asset_content_type: application/octet-stream + - name: Upload Release Asset ARMv6 + id: upload-release-asset + uses: actions/upload-release-asset@v1 + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps + asset_path: ./artifacts/zerobot-plugin-linux-armv6 + asset_name: zerobot-plugin-linux-armv6 + asset_content_type: application/octet-stream + \ No newline at end of file From 8147cd26dc91ee85f6ebabd879abb5c71b185b41 Mon Sep 17 00:00:00 2001 From: fumiama Date: Sat, 7 Aug 2021 01:43:06 +0800 Subject: [PATCH 74/79] =?UTF-8?q?=E2=9C=A8=20=E6=9B=B4=E6=96=B0=E7=BC=96?= =?UTF-8?q?=E8=AF=91?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/release.yml | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 1c038243..8d9a8bbc 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -55,7 +55,7 @@ jobs: prerelease: false - name: Upload Release Asset Linux x64 - id: upload-release-asset + id: upload-release-asset-lx64 uses: actions/upload-release-asset@v1 with: upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps @@ -63,7 +63,7 @@ jobs: asset_name: zerobot-plugin-linux-x64 asset_content_type: application/octet-stream - name: Upload Release Asset Linux x86 - id: upload-release-asset + id: upload-release-asset-lx86 uses: actions/upload-release-asset@v1 with: upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps @@ -71,7 +71,7 @@ jobs: asset_name: zerobot-plugin-linux-x86 asset_content_type: application/octet-stream - name: Upload Release Asset Windows x64 - id: upload-release-asset + id: upload-release-asset-wx64 uses: actions/upload-release-asset@v1 with: upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps @@ -79,7 +79,7 @@ jobs: asset_name: zerobot-plugin-windows-x64.exe asset_content_type: application/octet-stream - name: Upload Release Asset Windows x86 - id: upload-release-asset + id: upload-release-asset-wx86 uses: actions/upload-release-asset@v1 with: upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps @@ -87,7 +87,7 @@ jobs: asset_name: zerobot-plugin-windows-x86.exe asset_content_type: application/octet-stream - name: Upload Release Asset ARM64 - id: upload-release-asset + id: upload-release-asset-arm64 uses: actions/upload-release-asset@v1 with: upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps @@ -95,7 +95,7 @@ jobs: asset_name: zerobot-plugin-linux-arm64 asset_content_type: application/octet-stream - name: Upload Release Asset ARMv6 - id: upload-release-asset + id: upload-release-asset-armv6 uses: actions/upload-release-asset@v1 with: upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps From 4abd3803a323b70d3575db9b34d480a5a500a175 Mon Sep 17 00:00:00 2001 From: fumiama Date: Sat, 7 Aug 2021 01:46:03 +0800 Subject: [PATCH 75/79] =?UTF-8?q?=E2=9C=A8=20=E6=9B=B4=E6=96=B0=E7=BC=96?= =?UTF-8?q?=E8=AF=91?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/latest.yml | 32 +++----------------------------- 1 file changed, 3 insertions(+), 29 deletions(-) diff --git a/.github/workflows/latest.yml b/.github/workflows/latest.yml index fa9334d4..f898a531 100644 --- a/.github/workflows/latest.yml +++ b/.github/workflows/latest.yml @@ -45,34 +45,8 @@ jobs: - name: Build armv6 run: CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=6 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-armv6 - - name: Upload Build Artifact Linux x64 + - name: Upload Build Artifact uses: actions/upload-artifact@v2 with: - name: zerobot-plugin-linux-x64 - path: ./artifacts/zerobot-plugin-linux-x64 - - name: Upload Build Artifact Linux x86 - uses: actions/upload-artifact@v2 - with: - name: zerobot-plugin-linux-x86 - path: ./artifacts/zerobot-plugin-linux-x86 - - name: Upload Build Artifact Windows x64 - uses: actions/upload-artifact@v2 - with: - name: zerobot-plugin-windows-x64.exe - path: ./artifacts/zerobot-plugin-windows-x64.exe - - name: Upload Build Artifact Windows x86 - uses: actions/upload-artifact@v2 - with: - name: zerobot-plugin-windows-x86.exe - path: ./artifacts/zerobot-plugin-windows-x86.exe - - name: Upload Build Artifact Linux arm64 - uses: actions/upload-artifact@v2 - with: - name: zerobot-plugin-linux-arm64 - path: ./artifacts/zerobot-plugin-linux-arm64 - - name: Upload Build Artifact Linux armv6 - uses: actions/upload-artifact@v2 - with: - name: zerobot-plugin-linux-armv6 - path: ./artifacts/zerobot-plugin-linux-armv6 - + name: zerobot-plugin-all.zip + path: ./artifacts/zerobot-plugin-* \ No newline at end of file From a745f424adcc1a0e09179124bd43113182b6c23e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=BA=90=E6=96=87=E9=9B=A8?= <41315874+fumiama@users.noreply.github.com> Date: Sat, 7 Aug 2021 11:04:28 +0800 Subject: [PATCH 76/79] Update push.yml --- .github/workflows/push.yml | 33 +++++++++++---------------------- 1 file changed, 11 insertions(+), 22 deletions(-) diff --git a/.github/workflows/push.yml b/.github/workflows/push.yml index c07742d4..ad5510b0 100644 --- a/.github/workflows/push.yml +++ b/.github/workflows/push.yml @@ -2,30 +2,19 @@ name: PushLint on: [push] jobs: golangci: - name: lint + name: lint_golangci-lint runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v2.3.4 - name: golangci-lint - uses: golangci/golangci-lint-action@v2 + uses: golangci/golangci-lint-action@v2.5.2 with: - # Optional: version of golangci-lint to use in form of v1.2 or v1.2.3 or `latest` to use the latest version version: latest - - # Optional: working directory, useful for monorepos - # working-directory: somedir - - # Optional: golangci-lint command line arguments. - # args: --issues-exit-code=0 - - # Optional: show only new issues if it's a pull request. The default value is `false`. - # only-new-issues: true - - # Optional: if set to true then the action will use pre-installed Go. - # skip-go-installation: true - - # Optional: if set to true then the action don't cache or restore ~/go/pkg. - # skip-pkg-cache: true - - # Optional: if set to true then the action don't cache or restore ~/.cache/go-build. - # skip-build-cache: true + - name: Commit back + continue-on-error: true + run: | + git config --local user.name 'github-actions[bot]' + git config --local user.email '41898282+github-actions[bot]@users.noreply.github.com' + git add --all + git commit -m "🎨 改进代码样式" + git push From 7d5d74eb62c112c1b9e63b00ec97dd8e5fe2a2eb Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" <41898282+github-actions[bot]@users.noreply.github.com> Date: Sat, 7 Aug 2021 03:04:53 +0000 Subject: [PATCH 77/79] =?UTF-8?q?=F0=9F=8E=A8=20=E6=94=B9=E8=BF=9B?= =?UTF-8?q?=E4=BB=A3=E7=A0=81=E6=A0=B7=E5=BC=8F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugin_bilibili/fansDaily.go | 1 - plugin_diana/bing.go | 3 ++- plugin_diana/zhiwang.go | 1 - plugin_image_finder/keyword.go | 2 -- 4 files changed, 2 insertions(+), 5 deletions(-) diff --git a/plugin_bilibili/fansDaily.go b/plugin_bilibili/fansDaily.go index 7122a96a..9b5c3dae 100644 --- a/plugin_bilibili/fansDaily.go +++ b/plugin_bilibili/fansDaily.go @@ -106,7 +106,6 @@ func fansData(groupID int64) { // 请求api func fansapi(uid string) *follower { - url := "https://api.vtbs.moe/v1/detail/" + uid resp, err := http.Get(url) if err != nil { diff --git a/plugin_diana/bing.go b/plugin_diana/bing.go index 12cde0bf..026017b7 100644 --- a/plugin_diana/bing.go +++ b/plugin_diana/bing.go @@ -6,9 +6,10 @@ import ( "math/rand" "time" - "github.com/FloatTech/ZeroBot-Plugin/plugin_diana/data" zero "github.com/wdvxdr1123/ZeroBot" "github.com/wdvxdr1123/ZeroBot/message" + + "github.com/FloatTech/ZeroBot-Plugin/plugin_diana/data" ) func init() { diff --git a/plugin_diana/zhiwang.go b/plugin_diana/zhiwang.go index 52ca3967..db5c34da 100644 --- a/plugin_diana/zhiwang.go +++ b/plugin_diana/zhiwang.go @@ -66,7 +66,6 @@ func init() { // 发起api请求并把返回body交由json库解析 func zhiwangapi(text string) *zhiwang { - url := "https://asoulcnki.asia/v1/api/check" post := "{\n\"text\":\"" + text + "\"\n}" var jsonStr = []byte(post) diff --git a/plugin_image_finder/keyword.go b/plugin_image_finder/keyword.go index a5764416..ca739b6f 100644 --- a/plugin_image_finder/keyword.go +++ b/plugin_image_finder/keyword.go @@ -68,12 +68,10 @@ func init() { pom2 := soutujson.Illusts[rannum].ImageUrls.Large[19:] ctx.SendChain(message.Image(pom1 + pom2)) }) - } // soutuapi 请求api func soutuapi(keyword string) *resultjson { - url := "https://api.pixivel.moe/pixiv?type=search&page=0&mode=partial_match_for_tags&word=" + keyword method := "GET" From 4308d7637ce504714d1c62d5b45296a24a57f3bb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=BA=90=E6=96=87=E9=9B=A8?= <41315874+fumiama@users.noreply.github.com> Date: Sat, 7 Aug 2021 11:07:01 +0800 Subject: [PATCH 78/79] Update release.yml --- .github/workflows/release.yml | 11 +---------- 1 file changed, 1 insertion(+), 10 deletions(-) diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 8d9a8bbc..d6a1ec3c 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -45,15 +45,6 @@ jobs: - name: Build armv6 run: CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=6 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-armv6 - - name: Create Release - id: create_release - uses: actions/create-release@v1 - with: - tag_name: ${{ github.ref }} - release_name: Release ${{ github.ref }} - draft: false - prerelease: false - - name: Upload Release Asset Linux x64 id: upload-release-asset-lx64 uses: actions/upload-release-asset@v1 @@ -102,4 +93,4 @@ jobs: asset_path: ./artifacts/zerobot-plugin-linux-armv6 asset_name: zerobot-plugin-linux-armv6 asset_content_type: application/octet-stream - \ No newline at end of file + From 0a0ab96f41694905fdbea45f305f6e8f1615e712 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=BA=90=E6=96=87=E9=9B=A8?= <41315874+fumiama@users.noreply.github.com> Date: Sat, 7 Aug 2021 11:24:55 +0800 Subject: [PATCH 79/79] Update release.yml --- .github/workflows/release.yml | 55 +++++------------------------------ 1 file changed, 7 insertions(+), 48 deletions(-) diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index d6a1ec3c..d59f4750 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -45,52 +45,11 @@ jobs: - name: Build armv6 run: CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=6 go build -ldflags="-s -w" -o artifacts/zerobot-plugin-linux-armv6 - - name: Upload Release Asset Linux x64 - id: upload-release-asset-lx64 - uses: actions/upload-release-asset@v1 + - name: Upload binaries to release + uses: svenstaro/upload-release-action@v2 with: - upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps - asset_path: ./artifacts/zerobot-plugin-linux-x64 - asset_name: zerobot-plugin-linux-x64 - asset_content_type: application/octet-stream - - name: Upload Release Asset Linux x86 - id: upload-release-asset-lx86 - uses: actions/upload-release-asset@v1 - with: - upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps - asset_path: ./artifacts/zerobot-plugin-linux-x86 - asset_name: zerobot-plugin-linux-x86 - asset_content_type: application/octet-stream - - name: Upload Release Asset Windows x64 - id: upload-release-asset-wx64 - uses: actions/upload-release-asset@v1 - with: - upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps - asset_path: ./artifacts/zerobot-plugin-windows-x64.exe - asset_name: zerobot-plugin-windows-x64.exe - asset_content_type: application/octet-stream - - name: Upload Release Asset Windows x86 - id: upload-release-asset-wx86 - uses: actions/upload-release-asset@v1 - with: - upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps - asset_path: ./artifacts/zerobot-plugin-windows-x86.exe - asset_name: zerobot-plugin-windows-x86.exe - asset_content_type: application/octet-stream - - name: Upload Release Asset ARM64 - id: upload-release-asset-arm64 - uses: actions/upload-release-asset@v1 - with: - upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps - asset_path: ./artifacts/zerobot-plugin-linux-arm64 - asset_name: zerobot-plugin-linux-arm64 - asset_content_type: application/octet-stream - - name: Upload Release Asset ARMv6 - id: upload-release-asset-armv6 - uses: actions/upload-release-asset@v1 - with: - upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps - asset_path: ./artifacts/zerobot-plugin-linux-armv6 - asset_name: zerobot-plugin-linux-armv6 - asset_content_type: application/octet-stream - + repo_token: ${{ secrets.GITHUB_TOKEN }} + file: artifacts/zerobot-plugin-* + tag: ${{ github.ref }} + overwrite: true + file_glob: true