Initial Commit
This commit is contained in:
3
README.md
Normal file
3
README.md
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
# Whatsup-Poll
|
||||||
|
Scheduled Whatsapp Polls using [whatsmeow](https://github.com/tulir/whatsmeow).
|
||||||
|
Alternatively, [neonize](https://github.com/krypton-byte/neonize) python bindings.
|
||||||
135
main.go
Normal file
135
main.go
Normal 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()
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user