135 lines
3.4 KiB
Go
135 lines
3.4 KiB
Go
package main
|
|
|
|
import (
|
|
"encoding/base64"
|
|
"fmt"
|
|
"github.com/hpcloud/tail"
|
|
"github.com/jessevdk/go-flags"
|
|
"strings"
|
|
log "unknwon.dev/clog/v2"
|
|
|
|
dt "github.com/JetBlink/dingtalk-notify-go-sdk"
|
|
"os"
|
|
"regexp"
|
|
)
|
|
|
|
var (
|
|
AppName string
|
|
Version string
|
|
BuildTime string
|
|
GitCommit string
|
|
GoVersion string
|
|
|
|
versionTpl = `%s
|
|
Name: %s
|
|
Version: %s
|
|
BuildTime: %s
|
|
GitCommit: %s
|
|
GoVersion: %s
|
|
|
|
`
|
|
bannerBase64 = "DQogX18gIF9fICBfX19fXyAgXyAgXyAgX19fXyAgX19fXyAgX19fX18gIF9fX18gDQooICBcLyAgKSggIF8gICkoIFwoICkoXyAgXykoXyAgXykoICBfICApKCAgXyBcDQogKSAgICAoICApKF8pKCAgKSAgKCAgXykoXyAgICkoICAgKShfKSggICkgICAvDQooXy9cL1xfKShfX19fXykoXylcXykoX19fXykgKF9fKSAoX19fX18pKF8pXF8pDQo="
|
|
|
|
opts struct {
|
|
File string `short:"f" long:"monitor-file" env:"MONITOR_FILE" description:"The file to be monitored" required:"true"`
|
|
KeyWord string `short:"k" long:"search-keyword" env:"SEARCH_KEYWORD" description:"Keyword to be search for" default:"ERRO"`
|
|
KeyWordIgnoreCase bool `short:"c" long:"keyword-case-sensitive" env:"KEYWORD_IGNORE_CASE" description:"Whether Keyword ignore case"`
|
|
Version bool `short:"v" long:"version" description:"Show version info"`
|
|
Robot robot `group:"DingTalk Robot Options" namespace:"robot" env-namespace:"ROBOT" `
|
|
}
|
|
)
|
|
|
|
type robot struct {
|
|
Token string `short:"t" long:"token" env:"TOKEN" description:"DingTalk robot access token" required:"true"`
|
|
Secret string `short:"s" long:"secret" env:"SECRET" description:"DingTalk robot secret"`
|
|
AtMobiles []string `short:"m" long:"at-mobiles" env:"AT_MOBILES" env-delim:"," description:"The mobile of the person will be at"`
|
|
IsAtAll bool `short:"a" long:"at-all" env:"AT_ALL" description:"Whether at everyone"`
|
|
}
|
|
|
|
func init() {
|
|
initLog()
|
|
}
|
|
|
|
func main() {
|
|
parseArg()
|
|
|
|
tf, err := tail.TailFile(opts.File,
|
|
tail.Config{
|
|
ReOpen: true,
|
|
Follow: true,
|
|
Location: &tail.SeekInfo{Offset: 0, Whence: 2},
|
|
})
|
|
if err != nil {
|
|
log.Fatal("Tail file %+v", err)
|
|
}
|
|
log.Info("monitor file <%s>, filter by <%s>, ignore case <%v>...",
|
|
opts.File,
|
|
opts.KeyWord,
|
|
opts.KeyWordIgnoreCase)
|
|
|
|
dingTalk := dt.NewRobot(opts.Robot.Token, opts.Robot.Secret)
|
|
|
|
if opts.KeyWordIgnoreCase {
|
|
opts.KeyWord = strings.ToLower(opts.KeyWord)
|
|
}
|
|
for line := range tf.Lines {
|
|
text := line.Text
|
|
if opts.KeyWordIgnoreCase {
|
|
text = strings.ToLower(text)
|
|
}
|
|
|
|
if ok, _ := regexp.Match(opts.KeyWord, []byte(text)); ok {
|
|
err = dingTalk.SendTextMessage(line.Text, opts.Robot.AtMobiles, opts.Robot.IsAtAll)
|
|
if err != nil {
|
|
log.Error("%+v", err)
|
|
continue
|
|
}
|
|
|
|
log.Info("send message <%s> success", line.Text)
|
|
}
|
|
}
|
|
}
|
|
|
|
func initLog() {
|
|
err := log.NewConsole()
|
|
if err != nil {
|
|
panic("unable to create new logger: " + err.Error())
|
|
}
|
|
}
|
|
|
|
func parseArg() {
|
|
parser := flags.NewParser(&opts, flags.HelpFlag|flags.PassDoubleDash)
|
|
parser.NamespaceDelimiter = "-"
|
|
|
|
if AppName != "" {
|
|
parser.Name = AppName
|
|
}
|
|
|
|
if _, err := parser.Parse(); err != nil {
|
|
if opts.Version {
|
|
// -v
|
|
printVersion()
|
|
os.Exit(0)
|
|
}
|
|
|
|
if flagsErr, ok := err.(*flags.Error); ok && flagsErr.Type == flags.ErrHelp {
|
|
// -h
|
|
_, _ = fmt.Fprintln(os.Stdout, err)
|
|
os.Exit(0)
|
|
}
|
|
|
|
// err
|
|
_, _ = fmt.Fprintln(os.Stderr, err)
|
|
|
|
parser.WriteHelp(os.Stderr)
|
|
|
|
os.Exit(1)
|
|
}
|
|
}
|
|
|
|
// printVersion Print out version information
|
|
func printVersion() {
|
|
banner, _ := base64.StdEncoding.DecodeString(bannerBase64)
|
|
fmt.Printf(versionTpl, banner, AppName, Version, BuildTime, GitCommit, GoVersion)
|
|
}
|