dorisbot/pkg/svc/discord/actions.go

75 lines
1.5 KiB
Go

package discord
import (
dsmodel "dorisbot/models/discord"
pubmodel "dorisbot/models/public"
"log"
)
func addServer(info EvtInfo, name string) string {
exists, err := dsmodel.GetServerByID(info.Server)
if err != nil {
log.Println("check server exists fail :: ", err)
return "check server info fail"
}
if exists != nil {
return "server already setup"
}
ds, err := dsmodel.NewServer(info.Server, name, 0)
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"
}
func addFacebookPage(info EvtInfo, fbid, tmpl string) string {
ch, err := dsmodel.GetChannelByID(info.Channel)
if err != nil {
return ""
}
var page *pubmodel.FacebookPageModel
page, err = pubmodel.GetFacebookPageByID(fbid)
if err != nil {
return "check facebook fail"
}
if page == nil {
// TODO: write facebook page
page, err = pubmodel.NewFacebookPage(fbid)
if err != nil {
return "write data fail"
}
err = page.Write()
if err != nil {
return "write data fail"
}
} else {
fbrt, err := ch.GetFacebookPageByID(fbid)
if err != nil {
return "check data fail"
}
if fbrt != nil {
return "facebook page already linked"
}
}
return ""
}