tercul-backend/internal/app/bookmark/commands.go
Damir Mukimov d50722dad5
Some checks failed
Test / Integration Tests (push) Successful in 4s
Build / Build Binary (push) Failing after 2m9s
Docker Build / Build Docker Image (push) Failing after 2m32s
Test / Unit Tests (push) Failing after 3m12s
Lint / Go Lint (push) Failing after 1m0s
Refactor ID handling to use UUIDs across the application
- Updated database models and repositories to replace uint IDs with UUIDs.
- Modified test fixtures to generate and use UUIDs for authors, translations, users, and works.
- Adjusted mock implementations to align with the new UUID structure.
- Ensured all relevant functions and methods are updated to handle UUIDs correctly.
- Added necessary imports for UUID handling in various files.
2025-12-27 00:33:34 +01:00

84 lines
2.1 KiB
Go

package bookmark
import (
"context"
"tercul/internal/app/analytics"
"tercul/internal/domain"
"tercul/internal/platform/log"
"github.com/google/uuid"
)
// BookmarkCommands contains the command handlers for the bookmark aggregate.
type BookmarkCommands struct {
repo domain.BookmarkRepository
analyticsSvc analytics.Service
}
// NewBookmarkCommands creates a new BookmarkCommands handler.
func NewBookmarkCommands(repo domain.BookmarkRepository, analyticsSvc analytics.Service) *BookmarkCommands {
return &BookmarkCommands{
repo: repo,
analyticsSvc: analyticsSvc,
}
}
// CreateBookmarkInput represents the input for creating a new bookmark.
type CreateBookmarkInput struct {
Name string
UserID uuid.UUID
WorkID uuid.UUID
Notes string
}
// CreateBookmark creates a new bookmark.
func (c *BookmarkCommands) CreateBookmark(ctx context.Context, input CreateBookmarkInput) (*domain.Bookmark, error) {
bookmark := &domain.Bookmark{
Name: input.Name,
UserID: input.UserID,
WorkID: input.WorkID,
Notes: input.Notes,
}
err := c.repo.Create(ctx, bookmark)
if err != nil {
return nil, err
}
if c.analyticsSvc != nil {
go func() {
if err := c.analyticsSvc.IncrementWorkBookmarks(context.Background(), input.WorkID); err != nil {
log.Error(err, "failed to increment work bookmarks")
}
}()
}
return bookmark, nil
}
// UpdateBookmarkInput represents the input for updating an existing bookmark.
type UpdateBookmarkInput struct {
ID uuid.UUID
Name string
Notes string
}
// UpdateBookmark updates an existing bookmark.
func (c *BookmarkCommands) UpdateBookmark(ctx context.Context, input UpdateBookmarkInput) (*domain.Bookmark, error) {
bookmark, err := c.repo.GetByID(ctx, input.ID)
if err != nil {
return nil, err
}
bookmark.Name = input.Name
bookmark.Notes = input.Notes
err = c.repo.Update(ctx, bookmark)
if err != nil {
return nil, err
}
return bookmark, nil
}
// DeleteBookmark deletes a bookmark by ID.
func (c *BookmarkCommands) DeleteBookmark(ctx context.Context, id uuid.UUID) error {
return c.repo.Delete(ctx, id)
}