tercul-backend/internal/app/author/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

61 lines
1.4 KiB
Go

package author
import (
"context"
"tercul/internal/domain"
"github.com/google/uuid"
)
// AuthorCommands contains the command handlers for the author aggregate.
type AuthorCommands struct {
repo domain.AuthorRepository
}
// NewAuthorCommands creates a new AuthorCommands handler.
func NewAuthorCommands(repo domain.AuthorRepository) *AuthorCommands {
return &AuthorCommands{repo: repo}
}
// CreateAuthorInput represents the input for creating a new author.
type CreateAuthorInput struct {
Name string
}
// CreateAuthor creates a new author.
func (c *AuthorCommands) CreateAuthor(ctx context.Context, input CreateAuthorInput) (*domain.Author, error) {
author := &domain.Author{
Name: input.Name,
}
err := c.repo.Create(ctx, author)
if err != nil {
return nil, err
}
return author, nil
}
// UpdateAuthorInput represents the input for updating an existing author.
type UpdateAuthorInput struct {
ID uuid.UUID
Name string
}
// UpdateAuthor updates an existing author.
func (c *AuthorCommands) UpdateAuthor(ctx context.Context, input UpdateAuthorInput) (*domain.Author, error) {
author, err := c.repo.GetByID(ctx, input.ID)
if err != nil {
return nil, err
}
author.Name = input.Name
err = c.repo.Update(ctx, author)
if err != nil {
return nil, err
}
return author, nil
}
// DeleteAuthor deletes an author by ID.
func (c *AuthorCommands) DeleteAuthor(ctx context.Context, id uuid.UUID) error {
return c.repo.Delete(ctx, id)
}