dorisbot/pkg/svc/discord/actions.go

136 lines
2.8 KiB
Go
Raw Normal View History

2019-07-04 09:00:16 +00:00
package discord
2019-07-09 15:05:36 +00:00
import (
dsmodel "dorisbot/models/discord"
2019-07-22 12:54:25 +00:00
pubmodel "dorisbot/models/public"
2019-07-09 15:05:36 +00:00
"log"
)
func addServer(info EvtInfo, name string) string {
2019-07-21 01:41:06 +00:00
exists, err := dsmodel.GetServerByID(info.Server)
2019-07-09 15:05:36 +00:00
if err != nil {
log.Println("check server exists fail :: ", err)
return "check server info fail"
}
if exists != nil {
return "server already setup"
}
2019-07-21 01:41:06 +00:00
ds, err := dsmodel.NewServer(info.Server, name, 0)
2019-07-09 15:05:36 +00:00
if err != nil {
log.Println("create dsmodel fail :: ", err)
return "create server data fail"
}
log.Println("show info :: ", info)
owner, err := client.GetGuildOwner(info.Server)
if err != nil {
log.Println("get server owner err :: ", err)
return "get server owner fail"
}
ds.Owner = owner
err = ds.Write()
if err != nil {
log.Println("write server data fail :: ", err)
return "write server data fail"
}
return "add server success"
2019-07-04 09:00:16 +00:00
}
2019-07-13 09:44:31 +00:00
2019-08-25 11:27:00 +00:00
func addChannel(info EvtInfo, cmd, notify string) string {
server, err := dsmodel.GetServerByID(info.Server)
if err != nil {
return "Get server data fail"
}
_ = server
if server == nil {
return "Server not init"
}
ch, err := dsmodel.NewChannel(info.Channel, info.Server, cmd == "1", notify == "1")
if err != nil {
return "init channel data fail"
}
err = ch.Write()
if err != nil {
return "write channel data fail"
}
return "Success"
}
2019-07-13 09:44:31 +00:00
func addFacebookPage(info EvtInfo, fbid, tmpl string) string {
2019-08-25 03:47:34 +00:00
log.Printf("add facebook ::: id : %s ::: tmpl : %s \n", fbid, tmpl)
2019-07-22 12:54:25 +00:00
ch, err := dsmodel.GetChannelByID(info.Channel)
if err != nil {
2019-08-25 11:27:00 +00:00
log.Println("get channel fail", err)
2019-07-22 12:54:25 +00:00
return ""
}
var page *pubmodel.FacebookPageModel
2019-07-13 09:44:31 +00:00
2019-07-22 12:54:25 +00:00
page, err = pubmodel.GetFacebookPageByID(fbid)
if err != nil {
return "check facebook fail"
}
if page == nil {
page, err = pubmodel.NewFacebookPage(fbid)
if err != nil {
return "write data fail"
}
err = page.Write()
if err != nil {
return "write data fail"
}
2019-08-26 04:04:46 +00:00
rt, err := dsmodel.CreateFacebookRT(info.Channel, page.ID, tmpl)
if err != nil {
log.Println("create fail :: ", err)
return "create data fail"
}
err = rt.Write()
if err != nil {
return "write data fail"
}
2019-07-22 12:54:25 +00:00
} else {
fbrt, err := ch.GetFacebookPageByID(fbid)
if err != nil {
2019-08-25 11:27:00 +00:00
log.Println("get fb rt fail :: ", err)
2019-07-22 12:54:25 +00:00
return "check data fail"
}
2019-08-25 11:27:00 +00:00
2019-07-22 12:54:25 +00:00
if fbrt != nil {
return "facebook page already linked"
}
2019-08-19 15:13:38 +00:00
rt, err := dsmodel.CreateFacebookRT(info.Channel, page.ID, tmpl)
if err != nil {
2019-08-25 11:27:00 +00:00
log.Println("create fail :: ", err)
2019-08-19 15:13:38 +00:00
return "create data fail"
}
err = rt.Write()
if err != nil {
return "write data fail"
}
2019-07-22 12:54:25 +00:00
}
2019-08-19 15:13:38 +00:00
return "Success"
2019-07-13 09:44:31 +00:00
}
2019-08-20 09:29:06 +00:00
func delFacebookPage(info EvtInfo, fbid string) string {
ch, err := dsmodel.GetChannelByID(info.Channel)
if err != nil {
return ""
}
err = ch.DeleteFacebookPage(fbid)
if err != nil {
return "delete facebook page fail"
}
return "Success"
}