Fix ATM transfer between accounts support

This commit is contained in:
Illya Marchenko 2024-04-03 21:55:53 +03:00
parent 876edee3a7
commit 37e1445f3f
Signed by: stuzer05
GPG Key ID: A6ABAAA9268F9F4F
2 changed files with 10 additions and 20 deletions

@ -12,9 +12,8 @@ type Config struct {
} }
type ConfigAccount struct { type ConfigAccount struct {
Name string `json:"name"` Firefly3Name string `json:"firefly3_name,omitempty"`
Firefly3Id string `json:"firefly3_id,omitempty"` MonobankId string `json:"monobank_id,omitempty"`
MonobankId string `json:"monobank_id,omitempty"`
} }
type ConfigTransactionTypes struct { type ConfigTransactionTypes struct {
@ -57,16 +56,6 @@ func ReadConfig(path string) (Config, error) {
return config, nil return config, nil
} }
func ConfigGetAccountByName(config Config, q string) ConfigAccount {
for _, row := range config.Accounts {
if row.Name == q {
return row
}
}
return ConfigAccount{}
}
func ConfigGetAccountByMonobankId(config Config, q string) ConfigAccount { func ConfigGetAccountByMonobankId(config Config, q string) ConfigAccount {
for _, row := range config.Accounts { for _, row := range config.Accounts {
if row.MonobankId == q { if row.MonobankId == q {

@ -4,6 +4,7 @@ import (
"bytes" "bytes"
"context" "context"
"encoding/json" "encoding/json"
"fmt"
"github.com/antihax/optional" "github.com/antihax/optional"
"main/firefly3" "main/firefly3"
monobank "main/monobank/api/webhook/models" monobank "main/monobank/api/webhook/models"
@ -52,7 +53,7 @@ func handleWebhook(w http.ResponseWriter, r *http.Request) {
account := ConfigGetAccountByMonobankId(config, monobankTransaction.Data.Account) account := ConfigGetAccountByMonobankId(config, monobankTransaction.Data.Account)
// cancel if one of account ids is empty // cancel if one of account ids is empty
if len(account.Firefly3Id) == 0 || len(account.MonobankId) == 0 { if len(account.Firefly3Name) == 0 || len(account.MonobankId) == 0 {
LogString("cannot find firefly3 or monobank ids (" + monobankTransaction.Data.Account + ")") LogString("cannot find firefly3 or monobank ids (" + monobankTransaction.Data.Account + ")")
w.WriteHeader(http.StatusOK) w.WriteHeader(http.StatusOK)
return return
@ -126,10 +127,10 @@ func handleWebhook(w http.ResponseWriter, r *http.Request) {
// create firefly3 transaction // create firefly3 transaction
firefly3Transaction := firefly3.TransactionSplitStore{ firefly3Transaction := firefly3.TransactionSplitStore{
Date: time.Unix(int64(monobankTransaction.Data.StatementItem.Time), 0).Add(time.Hour * 2), Date: time.Unix(int64(monobankTransaction.Data.StatementItem.Time), 0).Add(time.Hour * 2),
Notes: string(monobankTransactionJson), Notes: string(monobankTransactionJson),
Amount: strconv.Itoa(int(math.Abs(math.Round(float64(monobankTransaction.Data.StatementItem.Amount/100)))) - int(math.Abs(math.Round(float64(monobankTransaction.Data.StatementItem.CommissionRate/100))))), Amount: strconv.Itoa(int(math.Abs(math.Round(float64(monobankTransaction.Data.StatementItem.Amount/100)))) - int(math.Abs(math.Round(float64(monobankTransaction.Data.StatementItem.CommissionRate/100))))),
SourceId: account.Firefly3Id, SourceName: account.Firefly3Name,
} }
// check max sum // check max sum
@ -172,7 +173,7 @@ func handleWebhook(w http.ResponseWriter, r *http.Request) {
Notes: string(monobankTransactionJson), Notes: string(monobankTransactionJson),
Description: "Transfer fee", Description: "Transfer fee",
Amount: strconv.Itoa(int(math.Abs(math.Round(float64(monobankTransaction.Data.StatementItem.CommissionRate / 100))))), Amount: strconv.Itoa(int(math.Abs(math.Round(float64(monobankTransaction.Data.StatementItem.CommissionRate / 100))))),
SourceId: account.Firefly3Id, SourceName: account.Firefly3Name,
}) })
} }
@ -186,7 +187,7 @@ func handleWebhook(w http.ResponseWriter, r *http.Request) {
Transactions: []firefly3.TransactionSplitStore{transaction}, Transactions: []firefly3.TransactionSplitStore{transaction},
}, &transactionOpts) }, &transactionOpts)
if err != nil { if err != nil {
LogString(err.Error()) fmt.Printf(err.Error())
w.WriteHeader(http.StatusOK) w.WriteHeader(http.StatusOK)
return return
} }