monobank-firefly3-bot/main.go

87 lines
2.4 KiB
Go
Raw Normal View History

2024-03-25 11:55:01 +02:00
package main
import (
2024-03-30 16:49:51 +02:00
"flag"
2024-03-25 11:55:01 +02:00
"fmt"
2024-04-10 23:24:16 +03:00
"gitea.stuzer.link/stuzer05/go-monobank"
2024-03-25 11:55:01 +02:00
"github.com/joho/godotenv"
2024-03-30 16:49:51 +02:00
"io"
2024-03-25 11:55:01 +02:00
"log"
"net/http"
2024-03-30 16:49:51 +02:00
"net/http/httptest"
2024-03-25 11:55:01 +02:00
"os"
2024-03-30 16:49:51 +02:00
"strings"
2024-03-25 11:55:01 +02:00
)
// https://api.monobank.ua/docs/index.html#tag/Kliyentski-personalni-dani/paths/~1personal~1statement~1{account}~1{from}~1{to}/get
// https://api-docs.firefly-iii.org/#/accounts/listAccount
// curl -X POST https://api.monobank.ua/personal/webhook -H 'Content-Type: application/json' -H 'X-Token: ' -d '{"webHookUrl":"https://monobank-firefly3.stuzer.link/webhook"}'
2024-03-25 11:55:01 +02:00
// curl -X POST https://monobank-firefly3.io.stuzer.link/webhook -H 'Content-Type: application/json' -d '{"test":123}'
2024-03-25 11:55:01 +02:00
func main() {
2024-03-27 20:12:24 +02:00
// load .env
2024-03-25 11:55:01 +02:00
err := godotenv.Load(".env")
if err != nil {
2024-04-05 16:51:49 +03:00
log.Fatalf("error loading .env file")
2024-03-25 11:55:01 +02:00
}
2024-03-27 21:22:51 +02:00
// test config read
_, err = ReadConfig(os.Getenv("CONFIG_PATH"))
if err != nil {
2024-04-05 16:50:00 +03:00
log.Fatalf("cannot read config - " + err.Error())
2024-03-27 21:22:51 +02:00
}
2024-03-30 16:49:51 +02:00
// flags
flagDoTransaction := flag.String("monobank-transaction", "", "run monobank transaction JSON manually")
2024-03-26 19:06:31 +02:00
2024-03-30 16:49:51 +02:00
flag.Parse()
// manual transaction
if len(*flagDoTransaction) > 0 {
w := httptest.NewRecorder()
r := &http.Request{
Method: http.MethodPost,
Header: make(http.Header),
Body: io.NopCloser(strings.NewReader(*flagDoTransaction)),
}
r.Header.Set("Content-Type", "application/json")
handleWebhook(w, r)
// @todo error logging
//response := w.Result()
//if response.StatusCode != http.StatusOK {
// os.Exit(1)
//}
} else {
2024-04-10 23:29:33 +03:00
webhookLocalUrl := fmt.Sprintf("/webhook/%s", os.Getenv("MONOBANK_WEBHOOK_SECRET"))
webhookUrl := fmt.Sprintf("https://%s/webhook/%s", os.Getenv("MONOBANK_WEBHOOK_DOMAIN"), os.Getenv("MONOBANK_WEBHOOK_SECRET"))
// register monobank webhook
2024-04-10 23:24:16 +03:00
monobankClientConf := monobank.NewConfiguration()
monobankClient := monobank.NewAPIClient(monobankClientConf)
req := monobank.ApiPersonalWebhookPostRequest{}
req = req.XToken(os.Getenv("MONOBANK_TOKEN"))
req = req.SetWebHook(monobank.SetWebHook{WebHookUrl: &webhookUrl})
_, err := monobankClient.DefaultApi.PersonalWebhookPostExecute(req)
if err != nil {
2024-04-10 16:21:55 +03:00
log.Fatalln("failed to register monobank webhook")
}
2024-03-30 16:49:51 +02:00
// set webhook
http.HandleFunc(webhookLocalUrl, handleWebhook)
2024-03-30 16:49:51 +02:00
// listen server
2024-04-05 16:51:49 +03:00
fmt.Println("webhook server listening on " + os.Getenv("LISTEN"))
fmt.Println("webhook url " + webhookUrl)
2024-03-30 16:49:51 +02:00
err = http.ListenAndServe(os.Getenv("LISTEN"), nil)
if err != nil {
2024-04-10 16:21:55 +03:00
log.Fatalln(err.Error())
2024-03-30 16:49:51 +02:00
}
2024-03-26 19:06:31 +02:00
}
2024-03-25 11:55:01 +02:00
}