mirror of
https://github.com/SamyRai/tercul-backend.git
synced 2025-12-27 02:51:34 +00:00
This commit marks the completion of a major refactoring effort to stabilize the codebase, improve its structure, and prepare it for production. The key changes include: - **Domain Layer Consolidation:** The `Work` entity and its related types, along with all other domain entities and repository interfaces, have been consolidated into the main `internal/domain` package. This eliminates import cycles and provides a single, coherent source of truth for the domain model. - **Data Access Layer Refactoring:** The repository implementations in `internal/data/sql` have been updated to align with the new domain layer. The `BaseRepositoryImpl` has been corrected to use pointer receivers, and all concrete repositories now correctly embed it, ensuring consistent and correct behavior. - **Application Layer Stabilization:** All application services in `internal/app` have been updated to use the new domain types and repository interfaces. Dependency injection has been corrected throughout the application, ensuring that all services are initialized with the correct dependencies. - **GraphQL Adapter Fixes:** The GraphQL resolver implementation in `internal/adapters/graphql` has been updated to correctly handle the new domain types and service methods. The auto-generated GraphQL code has been regenerated to ensure it is in sync with the schema and runtime. - **Test Suite Overhaul:** All test suites have been fixed to correctly implement their respective interfaces and use the updated domain model. Mock repositories and test suites have been corrected to properly embed the `testify` base types, resolving numerous build and linter errors. - **Dependency Management:** The Go modules have been tidied, and the module cache has been cleaned to ensure a consistent and correct dependency graph. - **Code Quality and Verification:** The entire codebase now passes all builds, tests, and linter checks, ensuring a high level of quality and stability. This comprehensive effort has resulted in a more robust, maintainable, and production-ready application.
36 lines
1.4 KiB
Go
36 lines
1.4 KiB
Go
package localization
|
|
|
|
import (
|
|
"context"
|
|
"tercul/internal/domain"
|
|
)
|
|
|
|
// LocalizationQueries contains the query handlers for the localization aggregate.
|
|
type LocalizationQueries struct {
|
|
repo domain.LocalizationRepository
|
|
}
|
|
|
|
// NewLocalizationQueries creates a new LocalizationQueries handler.
|
|
func NewLocalizationQueries(repo domain.LocalizationRepository) *LocalizationQueries {
|
|
return &LocalizationQueries{repo: repo}
|
|
}
|
|
|
|
// GetTranslation returns a translation for a given key and language.
|
|
func (q *LocalizationQueries) GetTranslation(ctx context.Context, key string, language string) (string, error) {
|
|
return q.repo.GetTranslation(ctx, key, language)
|
|
}
|
|
|
|
// GetTranslations returns a map of translations for a given set of keys and language.
|
|
func (q *LocalizationQueries) GetTranslations(ctx context.Context, keys []string, language string) (map[string]string, error) {
|
|
return q.repo.GetTranslations(ctx, keys, language)
|
|
}
|
|
|
|
// GetAuthorBiography returns the biography of an author in a specific language.
|
|
func (q *LocalizationQueries) GetAuthorBiography(ctx context.Context, authorID uint, language string) (string, error) {
|
|
return q.repo.GetAuthorBiography(ctx, authorID, language)
|
|
}
|
|
|
|
// GetWorkContent returns the content of a work in a specific language.
|
|
func (q *LocalizationQueries) GetWorkContent(ctx context.Context, workID uint, language string) (string, error) {
|
|
return q.repo.GetWorkContent(ctx, workID, language)
|
|
} |