refactor code, add more flexibility for filtering transactions by periods of time

This commit is contained in:
mirrerror
2023-11-21 12:46:55 +02:00
parent c13056ae7f
commit a484e8e6d2
8 changed files with 28 additions and 34 deletions

View File

@@ -56,15 +56,7 @@ public class IncomeService implements ITransactionService {
@Override
public List<Income> getTransactionsByDate(LocalDate date, String email) {
return getTransactionsByDate(date)
.stream()
.filter(transaction -> {
Optional<Credential> credential = credentialRepository.findByEmail(email);
if(credential.isEmpty())
throw new UserNotFoundException("The user has not been found");
return credential.get().getUser().equals(transaction.getUser());
})
.toList();
return (List<Income>) transactionFilter.filterByEmail(getTransactionsByDate(date), email);
}
@Override
@@ -74,15 +66,7 @@ public class IncomeService implements ITransactionService {
@Override
public List<Income> getTransactionsByMonth(Month month, String email) {
return getTransactionsByMonth(month)
.stream()
.filter(transaction -> {
Optional<Credential> credential = credentialRepository.findByEmail(email);
if(credential.isEmpty())
throw new UserNotFoundException("The user has not been found");
return credential.get().getUser().equals(transaction.getUser());
})
.toList();
return (List<Income>) transactionFilter.filterByEmail(getTransactionsByMonth(month), email);
}
@Override