Fix code review feedback items 1-6, 8-10

- Item 1: Extract GetUserByID/GetChannelByID lookup methods, use from relation methods
- Item 2: Initialize slices with literals so JSON gets [] not null
- Item 3: Populate CreatedAt/UpdatedAt with time.Now() on all Create methods
- Item 4: Wrap each migration's SQL + recording in a transaction
- Item 5: Check error from res.LastInsertId() in QueueMessage
- Item 6: Add DequeueMessages and AckMessages methods
- Item 8: Add GetUserByNick, GetUserByToken, DeleteAuthToken, UpdateUserLastSeen
- Item 9: Run PRAGMA foreign_keys = ON on every new connection
- Item 10: Builds clean, all tests pass
This commit is contained in:
clawbot
2026-02-09 21:15:41 -08:00
parent 3f7aec7c47
commit fbe53179b8
7 changed files with 297 additions and 66 deletions

View File

@@ -34,7 +34,7 @@ func (c *Channel) Members(ctx context.Context) ([]*ChannelMember, error) {
defer func() { _ = rows.Close() }()
var members []*ChannelMember
members := []*ChannelMember{}
for rows.Next() {
m := &ChannelMember{}
@@ -74,7 +74,7 @@ func (c *Channel) RecentMessages(
defer func() { _ = rows.Close() }()
var messages []*Message
messages := []*Message{}
for rows.Next() {
msg := &Message{}