From fc2a0e32cf1d402def52e28ed3d0b92fdd1f8e95 Mon Sep 17 00:00:00 2001 From: "Erik Winter (aider)" Date: Sat, 21 Dec 2024 14:05:04 +0100 Subject: [PATCH] fix: Handle null recurrer values consistently in PostgreSQL methods --- sync/service/postgres.go | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/sync/service/postgres.go b/sync/service/postgres.go index a4d6599..3bf5ed3 100644 --- a/sync/service/postgres.go +++ b/sync/service/postgres.go @@ -113,13 +113,13 @@ func (p *Postgres) Updated(ks []item.Kind, t time.Time) ([]item.Item, error) { for rows.Next() { var i item.Item var recurNext sql.NullTime - var recurrerJSON []byte + var recurrerJSON sql.NullString if err := rows.Scan(&i.ID, &i.Kind, &i.Updated, &i.Deleted, &i.Body, &recurrerJSON, &recurNext); err != nil { return nil, fmt.Errorf("%w: %v", ErrPostgresFailure, err) } - if len(recurrerJSON) > 0 { + if recurrerJSON.Valid && recurrerJSON.String != "" { var recurrer item.Recur - if err := json.Unmarshal(recurrerJSON, &recurrer); err != nil { + if err := json.Unmarshal([]byte(recurrerJSON.String), &recurrer); err != nil { return nil, fmt.Errorf("%w: %v", ErrPostgresFailure, err) } i.Recurrer = &recurrer @@ -149,11 +149,11 @@ func (p *Postgres) RecursBefore(date time.Time) ([]item.Item, error) { for rows.Next() { var i item.Item var recurNext sql.NullTime - var recurrerJSON []byte + var recurrerJSON sql.NullString if err := rows.Scan(&i.ID, &i.Kind, &i.Updated, &i.Deleted, &i.Body, &recurrerJSON, &recurNext); err != nil { return nil, fmt.Errorf("%w: %v", ErrPostgresFailure, err) } - if len(recurrerJSON) > 0 { + if recurrerJSON.Valid && recurrerJSON.String != "" { var recurrer item.Recur if err := json.Unmarshal(recurrerJSON, &recurrer); err != nil { return nil, fmt.Errorf("%w: %v", ErrPostgresFailure, err)