Add voucher compensation logic
parent
0f8fc0085e
commit
992864b785
|
@ -25,6 +25,16 @@ func handleSavedataGet(uuid []byte, datatype, slot int) (any, error) {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
compensations, err := db.FetchAndClaimAccountCompensations(uuid)
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf("failed to fetch compensations: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
for k, v := range compensations {
|
||||||
|
typeKey := strconv.Itoa(k)
|
||||||
|
system.VoucherCounts[typeKey] += v
|
||||||
|
}
|
||||||
|
|
||||||
return system, nil
|
return system, nil
|
||||||
case 1: // Session
|
case 1: // Session
|
||||||
if slot < 0 || slot >= sessionSlotCount {
|
if slot < 0 || slot >= sessionSlotCount {
|
||||||
|
@ -116,6 +126,8 @@ func handleSavedataUpdate(uuid []byte, slot int, save any) error {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("failed to write save file: %s", err)
|
return fmt.Errorf("failed to write save file: %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
db.DeleteClaimedAccountCompensations(uuid)
|
||||||
default:
|
default:
|
||||||
return fmt.Errorf("invalid data type")
|
return fmt.Errorf("invalid data type")
|
||||||
}
|
}
|
||||||
|
|
|
@ -100,6 +100,43 @@ func UpdateAccountStats(uuid []byte, stats defs.GameStats) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func FetchAndClaimAccountCompensations(uuid []byte) (map[int]int, error) {
|
||||||
|
var compensations = make(map[int]int)
|
||||||
|
|
||||||
|
results, err := handle.Query("SELECT voucherType, count FROM accountCompensations WHERE uuid = ?", uuid)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
defer results.Close()
|
||||||
|
|
||||||
|
for results.Next() {
|
||||||
|
var voucherType int
|
||||||
|
var count int
|
||||||
|
err := results.Scan(&voucherType, &count)
|
||||||
|
if err != nil {
|
||||||
|
return compensations, err
|
||||||
|
}
|
||||||
|
compensations[voucherType] = count
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err = handle.Exec("UPDATE accountCompensations SET claimed = 1 WHERE uuid = ?", uuid)
|
||||||
|
if err != nil {
|
||||||
|
return compensations, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return compensations, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func DeleteClaimedAccountCompensations(uuid []byte) error {
|
||||||
|
_, err := handle.Exec("DELETE FROM accountCompensations WHERE uuid = ? AND claimed = 1", uuid)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
func FetchUsernameFromToken(token []byte) (string, error) {
|
func FetchUsernameFromToken(token []byte) (string, error) {
|
||||||
var username string
|
var username string
|
||||||
err := handle.QueryRow("SELECT a.username FROM accounts a JOIN sessions s ON s.uuid = a.uuid WHERE s.token = ? AND s.expire > UTC_TIMESTAMP()", token).Scan(&username)
|
err := handle.QueryRow("SELECT a.username FROM accounts a JOIN sessions s ON s.uuid = a.uuid WHERE s.token = ? AND s.expire > UTC_TIMESTAMP()", token).Scan(&username)
|
||||||
|
|
Loading…
Reference in New Issue