Recount-Server/db.go

59 lines
1.6 KiB
Go
Raw Normal View History

2023-12-31 17:21:09 -08:00
package main
import (
"fmt"
_ "github.com/lib/pq"
_ "github.com/mattn/go-sqlite3"
"github.com/jmoiron/sqlx"
2024-01-01 20:47:34 -08:00
"github.com/rs/zerolog/log"
2023-12-31 17:21:09 -08:00
)
func db_get_transactions(transactions *[]Transaction,r *GetTransactionPaginationInput) (error) {
db, err := sqlx.Connect(DB_TYPE, DB_CONNECTION_STRING)
if err != nil {
2024-01-01 20:47:34 -08:00
log.Fatal().
Err(err).
Msg("Fatal error in db_get_transactions\nCannot connect to server")
2023-12-31 17:21:09 -08:00
}
defer db.Close()
err = db.Select(transactions,
"SELECT trns_id, trns_amount, trns_description, " +
"trns_account, trns_bucket, trns_date " +
fmt.Sprintf("FROM %stransactions ORDER BY trns_id DESC ", DB_SCHEMA) +
2024-01-01 22:18:43 -08:00
fmt.Sprintf("LIMIT %d OFFSET %d",
r.ResultCount, r.PageNum * r.ResultCount ))
2023-12-31 17:21:09 -08:00
if err != nil {
return err
}
return nil
}
func db_new_transaction(transaction Transaction) (error) {
db, err := sqlx.Connect(DB_TYPE, DB_CONNECTION_STRING)
if err != nil {
2024-01-01 20:47:34 -08:00
log.Info()
log.Fatal().
Err(err).
Msg("Fatal error in db_get_transactions\nCannot connect to server")
2023-12-31 17:21:09 -08:00
}
defer db.Close()
2024-01-01 22:18:43 -08:00
log.Debug().Msgf("%#v", transaction)
_, err = db.NamedExec(
2023-12-31 17:21:09 -08:00
fmt.Sprintf("INSERT INTO %stransactions", DB_SCHEMA) +
"(trns_amount, trns_description, trns_account, trns_bucket, trns_date)" +
"VALUES (:trns_amount, :trns_description, :trns_account, :trns_bucket, :trns_date)",
transaction)
if err != nil {
2024-01-01 20:47:34 -08:00
log.Fatal().
Err(err).
Msg("Could not exec insert db query")
2023-12-31 17:21:09 -08:00
}
return nil
}