Skip to content

Commit

Permalink
Prevent writing empty save files
Browse files Browse the repository at this point in the history
  • Loading branch information
patapancakes committed Apr 22, 2024
1 parent b00ed4c commit 697c533
Showing 1 changed file with 11 additions and 14 deletions.
25 changes: 11 additions & 14 deletions api/savedata/update.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,13 @@ func Update(uuid []byte, slot int, save any) error {
var filename string
var buf bytes.Buffer

zstdEncoder, err := zstd.NewWriter(&buf)
if err != nil {
return fmt.Errorf("failed to create zstd encoder: %s", err)
}

defer zstdEncoder.Close()

switch save := save.(type) {
case defs.SystemSaveData: // System
if save.TrainerId == 0 && save.SecretId == 0 {
Expand All @@ -46,13 +53,6 @@ func Update(uuid []byte, slot int, save any) error {

filename = "system"

zstdEncoder, err := zstd.NewWriter(&buf)
if err != nil {
return fmt.Errorf("failed to create zstd encoder: %s", err)
}

defer zstdEncoder.Close()

err = gob.NewEncoder(zstdEncoder).Encode(save)
if err != nil {
return fmt.Errorf("failed to serialize save: %s", err)
Expand All @@ -69,13 +69,6 @@ func Update(uuid []byte, slot int, save any) error {
filename += strconv.Itoa(slot)
}

zstdEncoder, err := zstd.NewWriter(&buf)
if err != nil {
return fmt.Errorf("failed to create zstd encoder: %s", err)
}

defer zstdEncoder.Close()

err = gob.NewEncoder(zstdEncoder).Encode(save)
if err != nil {
return fmt.Errorf("failed to serialize save: %s", err)
Expand All @@ -84,6 +77,10 @@ func Update(uuid []byte, slot int, save any) error {
return fmt.Errorf("invalid data type")
}

if buf.Len() == 0 {
return fmt.Errorf("tried to write empty save file")
}

err = os.WriteFile(fmt.Sprintf("userdata/%x/%s.pzs", uuid, filename), buf.Bytes(), 0644)
if err != nil {
return fmt.Errorf("failed to write save to disk: %s", err)
Expand Down

0 comments on commit 697c533

Please sign in to comment.