65 lines
1.6 KiB
Go
65 lines
1.6 KiB
Go
// codeberg.org/mapleopentech/monorepo/cloud/maplefile-backend/internal/usecase/filemetadata/restore.go
|
|
package filemetadata
|
|
|
|
import (
|
|
"context"
|
|
|
|
"go.uber.org/zap"
|
|
|
|
"github.com/gocql/gocql"
|
|
"codeberg.org/mapleopentech/monorepo/cloud/maplefile-backend/config"
|
|
dom_file "codeberg.org/mapleopentech/monorepo/cloud/maplefile-backend/internal/domain/file"
|
|
"codeberg.org/mapleopentech/monorepo/cloud/maplefile-backend/pkg/httperror"
|
|
)
|
|
|
|
type RestoreFileMetadataUseCase interface {
|
|
Execute(ctx context.Context, id gocql.UUID) error
|
|
}
|
|
|
|
type restoreFileMetadataUseCaseImpl struct {
|
|
config *config.Configuration
|
|
logger *zap.Logger
|
|
repo dom_file.FileMetadataRepository
|
|
}
|
|
|
|
func NewRestoreFileMetadataUseCase(
|
|
config *config.Configuration,
|
|
logger *zap.Logger,
|
|
repo dom_file.FileMetadataRepository,
|
|
) RestoreFileMetadataUseCase {
|
|
logger = logger.Named("RestoreFileMetadataUseCase")
|
|
return &restoreFileMetadataUseCaseImpl{config, logger, repo}
|
|
}
|
|
|
|
func (uc *restoreFileMetadataUseCaseImpl) Execute(ctx context.Context, id gocql.UUID) error {
|
|
//
|
|
// STEP 1: Validation.
|
|
//
|
|
|
|
e := make(map[string]string)
|
|
if id.String() == "" {
|
|
e["id"] = "File ID is required"
|
|
}
|
|
if len(e) != 0 {
|
|
uc.logger.Warn("Failed validating file metadata restoration",
|
|
zap.Any("error", e))
|
|
return httperror.NewForBadRequest(&e)
|
|
}
|
|
|
|
//
|
|
// STEP 2: Restore file metadata using repository method.
|
|
//
|
|
|
|
err := uc.repo.Restore(id)
|
|
if err != nil {
|
|
uc.logger.Error("Failed to restore file metadata",
|
|
zap.String("file_id", id.String()),
|
|
zap.Error(err))
|
|
return err
|
|
}
|
|
|
|
uc.logger.Info("File metadata successfully restored",
|
|
zap.String("file_id", id.String()))
|
|
|
|
return nil
|
|
}
|