You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

137 lines
2.3 KiB
Go

package main
import (
"fmt"
"log"
"os"
"os/signal"
"syscall"
"github.com/hugot/go-deltachat/deltabot"
"github.com/hugot/go-deltachat/deltachat"
"github.com/hugot/whapp-deltachat/botcommands"
"github.com/hugot/whapp-deltachat/whappdc"
core "github.com/hugot/whapp-deltachat/whappdc-core"
)
func main() {
argLen := len(os.Args)
if argLen != 2 {
fmt.Fprintln(os.Stderr, "Usage: whapp-deltachat CONFIG_FILE")
return
}
configPath := os.Args[1]
config, err := core.ConfigFromFile(configPath)
if err != nil {
log.Fatal(err)
}
ensureDirectoryOrDie(config.App.DataFolder)
ensureDirectoryOrDie(config.App.DataFolder + "/tmp")
db := core.NewDatabase(config.App.DataFolder + "/app.db")
err = db.Init()
messageTracker := &core.MessageTracker{
DB: db,
}
defer messageTracker.Flush()
if err != nil {
log.Fatal(err)
}
bridgeCtx := &core.BridgeContext{
Config: config,
DB: db,
MessageTracker: messageTracker,
}
dcClient, err := core.BootstrapDcClientFromConfig(*config, bridgeCtx)
bridgeCtx.SendLog("Whapp-Deltachat started.")
if err != nil {
log.Fatal(err)
}
// Give dc an opportunity to perform some close-down logic
// and close it's db etc.
defer dcClient.Close()
for i := 0; i < 10; i++ {
err = core.CreateAndLoginWhappConnection(
config.App.DataFolder,
bridgeCtx,
)
if err == nil {
break
}
}
if err != nil {
log.Fatal(err)
}
messageWorker := whappdc.NewMessageWorker()
messageWorker.Start()
bridgeCtx.WhappConn.AddHandler(&whappdc.WhappHandler{
BridgeContext: bridgeCtx,
MessageWorker: messageWorker,
})
bot := &deltabot.Bot{}
bot.AddCommand(&botcommands.Echo{})
bot.AddCommand(botcommands.NewWhappBridge(
bridgeCtx.WhappConn, bridgeCtx.DB, bridgeCtx.DCUserChatID,
))
dcClient.On(deltachat.DC_EVENT_INCOMING_MSG, bot.HandleMessage)
wait := make(chan os.Signal, 1)
signal.Notify(wait, os.Interrupt, syscall.SIGTERM)
for {
select {
case sig := <-wait:
log.Println(sig)
return
}
}
}
func ensureDirectory(dir string) error {
if _, err := os.Stat(dir); os.IsNotExist(err) {
err = os.MkdirAll(dir, 0700)
if err != nil {
return err
}
}
err := os.Chmod(dir, 0700)
if err != nil {
return err
}
return nil
}
func ensureDirectoryOrDie(dir string) {
err := ensureDirectory(dir)
if err != nil {
log.Fatal(err)
}
}