Initial Commit

This commit is contained in:
eneller
2025-04-26 22:23:14 +02:00
commit d14c47ed9d
2 changed files with 138 additions and 0 deletions

135
main.go Normal file
View File

@@ -0,0 +1,135 @@
// from https://github.com/tulir/whatsmeow/issues/659
package main
import (
"context"
"fmt"
"os"
"strconv"
"time"
_ "github.com/mattn/go-sqlite3"
"github.com/mdp/qrterminal/v3"
"go.mau.fi/whatsmeow"
"go.mau.fi/whatsmeow/store/sqlstore"
"go.mau.fi/whatsmeow/types"
"go.mau.fi/whatsmeow/types/events"
waLog "go.mau.fi/whatsmeow/util/log"
)
func eventHandler(evt interface{}) {
switch v := evt.(type) {
case *events.Message:
fmt.Println("Received a message from !", v.Info.Sender)
fmt.Println("Received a message!", v.Message.GetConversation())
}
}
func main() {
dbLog := waLog.Stdout("Database", "DEBUG", true)
// Make sure you add appropriate DB connector imports, e.g. github.com/mattn/go-sqlite3 for SQLite
container, err := sqlstore.New("sqlite3", "file:examplestore.db?_foreign_keys=on", dbLog)
if err != nil {
panic(err)
}
// If you want multiple sessions, remember their JIDs and use .GetDevice(jid) or .GetAllDevices() instead.
deviceStore, err := container.GetFirstDevice()
if err != nil {
panic(err)
}
clientLog := waLog.Stdout("Client", "DEBUG", true)
client := whatsmeow.NewClient(deviceStore, clientLog)
client.AddEventHandler(eventHandler)
if client.Store.ID == nil {
fmt.Println("Client store ID is nil, scanning QR")
// No ID stored, new login
qrChan, _ := client.GetQRChannel(context.Background())
err = client.Connect()
if err != nil {
panic(err)
}
for evt := range qrChan {
if evt.Event == "code" {
// Render the QR code here
// e.g. qrterminal.GenerateHalfBlock(evt.Code, qrterminal.L, os.Stdout)
qrterminal.GenerateHalfBlock(evt.Code, qrterminal.L, os.Stdout)
// or just manually `echo 2@... | qrencode -t ansiutf8` in a terminal
fmt.Println("QR code:", evt.Code)
} else {
fmt.Println("Login event:", evt.Event)
}
}
} else {
// Already logged in, just connect
fmt.Println("Connecting")
err = client.Connect()
if err != nil {
panic(err)
}
}
strJID := "XXXXXXXX@g.us"
var gJID types.JID
gJID, err = types.ParseJID(strJID)
if err != nil {
fmt.Println("Failed to parse JID: ", strJID)
} else {
fmt.Println("Parsed JID correctly", gJID)
}
var optionNames []string
optionNames = append(optionNames, "O1")
optionNames = append(optionNames, "O2")
currentTime := time.Now()
var headline string
var daysShift int = -1
if len(os.Args) > 1 {
daysShift, err = strconv.Atoi(os.Args[1])
if err != nil {
fmt.Println("Failed to parse days shift param: ", os.Args[1])
os.Exit(-1)
}
fmt.Println("Parsed days shift param: ", daysShift)
currentTime = currentTime.AddDate(0, 0, daysShift)
} else {
// If after 8 AM, simply we are generating for the next day
if currentTime.Hour() >= 8 {
currentTime = currentTime.AddDate(0, 0, 1)
}
}
headline = "Auto-generated: " + fmt.Sprintf("%d/%d/%d", currentTime.Day(), currentTime.Month(), currentTime.Year())
fmt.Println(headline)
pollMessage := client.BuildPollCreation(headline, optionNames, 1)
fmt.Println("Create Poll Message succuessfully : ", pollMessage)
_, err = client.SendMessage(context.Background(), gJID, pollMessage)
if err != nil {
fmt.Println("Sent Poll Succuessfully ", strJID)
} else {
fmt.Println("Failed to Send Poll", gJID)
}
time.Sleep(5 * time.Second)
// Listen to Ctrl+C (you can also do something else that prevents the program from exiting)
// c := make(chan os.Signal, 1)
// signal.Notify(c, os.Interrupt, syscall.SIGTERM)
// <-c
client.Disconnect()
container.Close()
}