update
parent
bf27136a4d
commit
6d9d87c00b
|
@ -0,0 +1,55 @@
|
|||
package main
|
||||
|
||||
import (
|
||||
"github.com/line/line-bot-sdk-go/v7/linebot"
|
||||
"github.com/rs/zerolog/log"
|
||||
)
|
||||
|
||||
func Follow(event *linebot.Event) {
|
||||
// add user
|
||||
uid := event.Source.UserID
|
||||
usr := &User{
|
||||
ID: uid,
|
||||
}
|
||||
Hit("加入", uid)
|
||||
|
||||
reply := event.ReplyToken
|
||||
|
||||
row := DB.Exec("select id from users where id = ?", uid).RowsAffected
|
||||
if row == 0 {
|
||||
// 新用戶
|
||||
if err := DB.Create(usr).Error; err != nil {
|
||||
log.Error().Err(err).Msg("Follow error.")
|
||||
return
|
||||
}
|
||||
|
||||
// 舊用戶
|
||||
log.Debug().Str("user", uid).Msg("New user.")
|
||||
msg := linebot.NewTextMessage("你好!")
|
||||
if reply != "" {
|
||||
if _, err := bot.ReplyMessage(reply, msg).Do(); err != nil {
|
||||
log.Error().Err(err).Caller().Msg("reply error")
|
||||
}
|
||||
} else {
|
||||
if _, err := bot.PushMessage(uid, msg).Do(); err != nil {
|
||||
log.Error().Err(err).Caller().Msg("push error")
|
||||
}
|
||||
}
|
||||
|
||||
} else {
|
||||
// 舊用戶
|
||||
log.Debug().Str("user", uid).Msg("user unblocked.")
|
||||
msg := linebot.NewTextMessage("歡迎回來!")
|
||||
if reply != "" {
|
||||
if _, err := bot.ReplyMessage(reply, msg).Do(); err != nil {
|
||||
log.Error().Err(err).Caller().Msg("reply error")
|
||||
}
|
||||
} else {
|
||||
if _, err := bot.PushMessage(uid, msg).Do(); err != nil {
|
||||
log.Error().Err(err).Caller().Msg("push error")
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Welcome and ask for
|
||||
}
|
|
@ -26,7 +26,7 @@ for PLATFORM in $PLATFORMS; do
|
|||
scp ${DIST}/${BIN_FILENAME} root@bot.ework.tw:~
|
||||
ssh root@bot.ework.tw chmod +x talent
|
||||
ssh root@bot.ework.tw screen -X quit
|
||||
ssh root@bot.ework.tw screen -d -m "./talent -dev -db-name talentdev > talent.log"
|
||||
ssh root@bot.ework.tw screen -d -m bash -c './talent -dev -db-name talentdev | tee talent.log'
|
||||
done
|
||||
|
||||
if [[ "${FAILURES}" != "" ]]; then
|
||||
|
|
|
@ -34,56 +34,20 @@ func webhook(c *gin.Context) {
|
|||
if event.Type == linebot.EventTypeFollow {
|
||||
Follow(event)
|
||||
}
|
||||
if event.Type == linebot.EventTypeMessage {
|
||||
controller(event)
|
||||
}
|
||||
}
|
||||
|
||||
OK(c, "ok")
|
||||
}
|
||||
|
||||
func Follow(event *linebot.Event) {
|
||||
// add user
|
||||
uid := event.Source.UserID
|
||||
usr := &User{
|
||||
ID: uid,
|
||||
}
|
||||
Hit("加入", uid)
|
||||
func controller(event *linebot.Event) {
|
||||
switch event.Source.Ty {
|
||||
case "":
|
||||
|
||||
reply := event.ReplyToken
|
||||
|
||||
row := DB.Exec("select id from users where id = ?", uid).RowsAffected
|
||||
if row == 0 {
|
||||
// 新用戶
|
||||
if err := DB.Create(usr).Error; err != nil {
|
||||
log.Error().Err(err).Msg("Follow error.")
|
||||
return
|
||||
}
|
||||
|
||||
// 舊用戶
|
||||
log.Debug().Str("user", uid).Msg("New user.")
|
||||
msg := linebot.NewTextMessage("你好!")
|
||||
if reply != "" {
|
||||
if _, err := bot.ReplyMessage(reply, msg).Do(); err != nil {
|
||||
log.Error().Err(err).Caller().Msg("reply error")
|
||||
}
|
||||
} else {
|
||||
if _, err := bot.PushMessage(uid, msg).Do(); err != nil {
|
||||
log.Error().Err(err).Caller().Msg("push error")
|
||||
default:
|
||||
// route to watson
|
||||
log.Error().Caller().Msg("NOT IMPLEMENTED")
|
||||
}
|
||||
}
|
||||
|
||||
} else {
|
||||
// 舊用戶
|
||||
log.Debug().Str("user", uid).Msg("user unblocked.")
|
||||
msg := linebot.NewTextMessage("歡迎回來!")
|
||||
if reply != "" {
|
||||
if _, err := bot.ReplyMessage(reply, msg).Do(); err != nil {
|
||||
log.Error().Err(err).Caller().Msg("reply error")
|
||||
}
|
||||
} else {
|
||||
if _, err := bot.PushMessage(uid, msg).Do(); err != nil {
|
||||
log.Error().Err(err).Caller().Msg("push error")
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Welcome and ask for
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue