// codeberg.org/mapleopentech/monorepo/cloud/maplefile-backend/internal/usecase/user/getbyid.go package user import ( "context" "go.uber.org/zap" "codeberg.org/mapleopentech/monorepo/cloud/maplefile-backend/config" dom_user "codeberg.org/mapleopentech/monorepo/cloud/maplefile-backend/internal/domain/user" "codeberg.org/mapleopentech/monorepo/cloud/maplefile-backend/pkg/httperror" ) type UserDeleteUserByEmailUseCase interface { Execute(ctx context.Context, email string) error } type userDeleteUserByEmailImpl struct { config *config.Configuration logger *zap.Logger repo dom_user.Repository } func NewUserDeleteUserByEmailUseCase(config *config.Configuration, logger *zap.Logger, repo dom_user.Repository) UserDeleteUserByEmailUseCase { logger = logger.Named("UserDeleteUserByEmailUseCase") return &userDeleteUserByEmailImpl{config, logger, repo} } func (uc *userDeleteUserByEmailImpl) Execute(ctx context.Context, email string) error { // // STEP 1: Validation. // e := make(map[string]string) if email == "" { e["email"] = "missing value" } else { //TODO: IMPL. } if len(e) != 0 { uc.logger.Warn("Validation failed for upsert", zap.Any("error", e)) return httperror.NewForBadRequest(&e) } // // STEP 2: Get from database. // return uc.repo.DeleteByEmail(ctx, email) }