From aef0b00fb9c2236bbc3fa85e486e2b44cba494d3 Mon Sep 17 00:00:00 2001 From: Julien Dessaux Date: Sun, 12 Jan 2025 00:15:52 +0100 Subject: feat(tfstated): store created and updated timestamps for states --- pkg/database/sql/000_init.sql | 4 +++- pkg/database/states.go | 16 ++++++++++++---- 2 files changed, 15 insertions(+), 5 deletions(-) (limited to 'pkg/database') diff --git a/pkg/database/sql/000_init.sql b/pkg/database/sql/000_init.sql index e14142b..0bcdee1 100644 --- a/pkg/database/sql/000_init.sql +++ b/pkg/database/sql/000_init.sql @@ -26,7 +26,9 @@ CREATE TABLE sessions ( CREATE TABLE states ( id INTEGER PRIMARY KEY, path TEXT NOT NULL, - lock TEXT + lock TEXT, + created INTEGER DEFAULT (unixepoch()), + updated INTEGER DEFAULT (unixepoch()) ) STRICT; CREATE UNIQUE INDEX states_path on states(path); diff --git a/pkg/database/states.go b/pkg/database/states.go index 74839da..d88e717 100644 --- a/pkg/database/states.go +++ b/pkg/database/states.go @@ -5,6 +5,7 @@ import ( "errors" "fmt" "slices" + "time" ) // returns true in case of successful deletion @@ -46,7 +47,7 @@ func (db *DB) GetState(path string) ([]byte, error) { func (db *DB) SetState(path string, accountID int, data []byte, lockID string) (bool, error) { encryptedData, err := db.dataEncryptionKey.EncryptAES256(data) if err != nil { - return false, err + return false, fmt.Errorf("failed to encrypt state data: %w", err) } ret := false return ret, db.WithTransaction(func(tx *sql.Tx) error { @@ -59,11 +60,11 @@ func (db *DB) SetState(path string, accountID int, data []byte, lockID string) ( var result sql.Result result, err = tx.ExecContext(db.ctx, `INSERT INTO states(path) VALUES (?)`, path) if err != nil { - return err + return fmt.Errorf("failed to insert new state: %w", err) } stateID, err = result.LastInsertId() if err != nil { - return err + return fmt.Errorf("failed to get last insert id for new state: %w", err) } } else { return err @@ -84,7 +85,14 @@ func (db *DB) SetState(path string, accountID int, data []byte, lockID string) ( sql.Named("stateID", stateID), sql.Named("data", encryptedData)) if err != nil { - return err + return fmt.Errorf("failed to insert new state version: %w", err) + } + _, err = tx.ExecContext(db.ctx, + `UPDATE states SET updated = ? WHERE id = ?;`, + time.Now().UTC().Unix(), + stateID) + if err != nil { + return fmt.Errorf("failed to touch updated for state: %w", err) } _, err = tx.ExecContext(db.ctx, `DELETE FROM versions -- cgit v1.2.3