Compare commits

..

10 Commits

Author SHA1 Message Date
18acbd3b32 Merge pull request 'refactor(service): унификация операций с сущностями и обновление команды list (close #49)' (#58) from feature/refactor-taskservice into dev
Reviewed-on: #58
2025-06-07 16:27:18 +03:00
56038f62f7 refactor(service): унификация операций с сущностями и обновление команды list (close #49)
- Обновление ListCommand для использования метода getAll() вместо list()
- Рефакторинг EntityService для предоставления универсальных CRUD-операций
- Изменение TaskService для расширения EntityService и использования его методов
2025-06-07 16:26:41 +03:00
728cb4f84f Merge pull request 'feat(service): создан универсальный EntityService для операций CRUD (close #48)' (#57) from feature/entity-service into dev
Reviewed-on: #57
2025-06-07 15:31:24 +03:00
5140228f3e feat(service): создан универсальный EntityService для операций CRUD (close #48)
- Реализован универсальный класс EntityService для стандартных операций CRUD
- Определены методы для сохранения, получения и удаления сущностей
- Предоставлена основа для реализации специализированных сервисов
2025-06-07 15:21:55 +03:00
0174224089 Merge pull request 'refactor(repo): переименование и реструктуризация классов репозитория (close #47)' (#56) from feature/inmemory-repository into dev
Reviewed-on: #56
2025-06-06 20:34:20 +03:00
8c0cc0aa06 refactor(repo): переименование и реструктуризация классов репозитория (close #47)
- Переименован InMemoryTaskRepository в InMemoryRepository
- Обновлён TaskService для использования InMemoryRepository вместо TaskRepository
- Удалён интерфейс TaskRepository
- Обновлены импорты и ссылки на классы
2025-06-06 20:33:35 +03:00
da878ec81c Merge pull request 'refactor(repo): внедрение универсального интерфейса Repository и упрощение работы с моделью задач (close #46)' (#55) from feature/generic-repository into dev
Reviewed-on: #55
2025-06-06 19:31:56 +03:00
4cd38a9afe refactor(todo): внедрение универсального интерфейса Repository и упрощение работы с моделью задач (close #46)
- Добавлен интерфейс Repository для базовых CRUD-операций
- Обновлён TaskRepository для наследования от Repository<SimpleTask>
- Рефакторинг InMemoryTaskRepository для работы с SimpleTask
- Настройка ListCommand и TaskService для прямой работы с SimpleTask
- Удалено лишнее приведение типов и улучшена типобезопасность
2025-06-06 19:30:39 +03:00
2c7deaa9ae Merge pull request 'добавление интерфейса Identifiable и его реализация в Task (closes #45)' (#54) from feature/add-identifiable into dev
Reviewed-on: #54
2025-06-06 18:15:53 +03:00
8399ab0d58 добавление интерфейса Identifiable и его реализация в Task (closes #45)
- Создан интерфейс Identifiable с методом getId()
- Реализован Identifiable в классе Task
- Переопределён метод getId() в Task
- Сохранён существующий метод id() для обратной совместимости
2025-06-06 18:13:21 +03:00
9 changed files with 84 additions and 60 deletions

View File

@ -3,12 +3,13 @@ package ru.kamask.pet.todo;
import java.io.IOException; import java.io.IOException;
import ru.kamask.pet.todo.cli.CliEngine; import ru.kamask.pet.todo.cli.CliEngine;
import ru.kamask.pet.todo.repo.InMemoryTaskRepository; import ru.kamask.pet.todo.model.SimpleTask;
import ru.kamask.pet.todo.repo.InMemoryRepository;
import ru.kamask.pet.todo.service.TaskService; import ru.kamask.pet.todo.service.TaskService;
public class TodoApp { public class TodoApp {
public static void main(String[] args) throws IOException { public static void main(String[] args) throws IOException {
var service = new TaskService(new InMemoryTaskRepository()); var service = new TaskService(new InMemoryRepository<SimpleTask>());
var cli = new CliEngine(service); var cli = new CliEngine(service);
cli.start(); cli.start();

View File

@ -4,7 +4,6 @@ import java.util.List;
import java.util.Optional; import java.util.Optional;
import ru.kamask.pet.todo.model.SimpleTask; import ru.kamask.pet.todo.model.SimpleTask;
import ru.kamask.pet.todo.model.Task;
import ru.kamask.pet.todo.service.TaskService; import ru.kamask.pet.todo.service.TaskService;
public class ListCommand implements Command { public class ListCommand implements Command {
@ -18,7 +17,7 @@ public class ListCommand implements Command {
if (args.length > 0) if (args.length > 0)
return Optional.of(Command.errorMessage); return Optional.of(Command.errorMessage);
var res = formatWithTable(service.list(), "Список задач пуст."); var res = formatWithTable(service.getAll(), "Список задач пуст.");
return Optional.of(res); return Optional.of(res);
} }
@ -28,7 +27,7 @@ public class ListCommand implements Command {
return String.format(templateUsage, name(), "Список всех задач."); return String.format(templateUsage, name(), "Список всех задач.");
} }
String formatWithTable(List<Task> tasks, String msgIfEmpty) { String formatWithTable(List<SimpleTask> tasks, String msgIfEmpty) {
String template = "%-2s | %-30s | %s\n"; String template = "%-2s | %-30s | %s\n";
var res = new StringBuilder(String.format(template, "ID", "Название задачи", "Статус")); var res = new StringBuilder(String.format(template, "ID", "Название задачи", "Статус"));
res.append("-".repeat(50) + "\n"); res.append("-".repeat(50) + "\n");
@ -36,8 +35,8 @@ public class ListCommand implements Command {
if (tasks.size() == 0) if (tasks.size() == 0)
return res.append("\n" + msgIfEmpty).toString(); return res.append("\n" + msgIfEmpty).toString();
for (Task task : tasks) { for (SimpleTask task : tasks) {
SimpleTask.Data data = ((SimpleTask) task).data(); SimpleTask.Data data = task.data();
res.append(String.format(template, data.id(), data.title(), data.done() ? "выполнено" : "не выполнено")); res.append(String.format(template, data.id(), data.title(), data.done() ? "выполнено" : "не выполнено"));
} }

View File

@ -0,0 +1,5 @@
package ru.kamask.pet.todo.model;
public interface Identifiable {
int getId();
}

View File

@ -1,6 +1,6 @@
package ru.kamask.pet.todo.model; package ru.kamask.pet.todo.model;
public abstract class Task { public abstract class Task implements Identifiable{
private static int nextId = 1; private static int nextId = 1;
protected int id; protected int id;
@ -11,10 +11,15 @@ public abstract class Task {
this.title = title; this.title = title;
} }
public int id() { @Override
public int getId() {
return id; return id;
} }
public int id() {
return getId();
}
@Override @Override
public String toString() { public String toString() {
return String.format("Задача: id - %d, title: \"%s\"", id, title); return String.format("Задача: id - %d, title: \"%s\"", id, title);

View File

@ -6,23 +6,23 @@ import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Optional; import java.util.Optional;
import ru.kamask.pet.todo.model.Task; import ru.kamask.pet.todo.model.Identifiable;
public class InMemoryTaskRepository implements TaskRepository { public class InMemoryRepository<T extends Identifiable> implements Repository<T> {
private Map<Integer, Task> storage = new HashMap<>(); private Map<Integer, T> storage = new HashMap<>();
@Override @Override
public void save(Task task) { public void save(T obj) {
storage.put(task.id(), task); storage.put(obj.getId(), obj);
} }
@Override @Override
public Optional<Task> findById(int id) { public Optional<T> findById(int id) {
return Optional.ofNullable(storage.get(id)); return Optional.ofNullable(storage.get(id));
} }
@Override @Override
public List<Task> findAll() { public List<T> findAll() {
return new ArrayList<>(storage.values()); return new ArrayList<>(storage.values());
} }

View File

@ -0,0 +1,14 @@
package ru.kamask.pet.todo.repo;
import java.util.List;
import java.util.Optional;
import ru.kamask.pet.todo.model.Identifiable;
public interface Repository<T extends Identifiable> {
void save(T obj);
Optional<T> findById(int id);
List<T> findAll();
void delete(int id);
boolean has(int id);
}

View File

@ -1,18 +0,0 @@
package ru.kamask.pet.todo.repo;
import java.util.List;
import java.util.Optional;
import ru.kamask.pet.todo.model.Task;
public interface TaskRepository {
void save(Task task);
Optional<Task> findById(int id);
List<Task> findAll();
void delete(int id);
boolean has(int id);
}

View File

@ -0,0 +1,35 @@
package ru.kamask.pet.todo.service;
import java.util.List;
import java.util.Optional;
import ru.kamask.pet.todo.model.Identifiable;
import ru.kamask.pet.todo.repo.Repository;
public class EntityService<T extends Identifiable> {
private final Repository<T> repo;
protected EntityService(Repository<T> repo) {
this.repo = repo;
}
public void save(T obj) {
repo.save(obj);
}
public Optional<T> getById(int id) {
return repo.findById(id);
}
public List<T> getAll() {
return repo.findAll();
}
public void remove(int id) {
repo.delete(id);
}
public boolean has(int id) {
return repo.has(id);
}
}

View File

@ -1,29 +1,23 @@
package ru.kamask.pet.todo.service; package ru.kamask.pet.todo.service;
import java.util.List; import java.util.List;
import java.util.Optional;
import ru.kamask.pet.todo.model.Task;
import ru.kamask.pet.todo.model.SimpleTask; import ru.kamask.pet.todo.model.SimpleTask;
import ru.kamask.pet.todo.repo.TaskRepository; import ru.kamask.pet.todo.repo.Repository;
public class TaskService { public class TaskService extends EntityService<SimpleTask> {
private final TaskRepository repo;
public TaskService(TaskRepository repo) { public TaskService(Repository<SimpleTask> repo) {
this.repo = repo; super(repo);
} }
public void create(String title) { public void create(String title) {
repo.save(new SimpleTask(title)); super.save(new SimpleTask(title));
} }
public Optional<Task> getById(int id) {
return repo.findById(id);
}
public boolean complete(int id) { public boolean complete(int id) {
var taskOpt = repo.findById(id); var taskOpt = super.getById(id);
if (taskOpt.isPresent()) { if (taskOpt.isPresent()) {
taskOpt.get().markAsCompleted(); taskOpt.get().markAsCompleted();
return true; return true;
@ -31,21 +25,10 @@ public class TaskService {
return false; return false;
} }
public List<Task> list() {
return repo.findAll();
}
public void remove(int id) { public List<SimpleTask> search(String query) {
repo.delete(id); return super.getAll().stream()
} .filter(task -> task.data().title().contains(query))
public boolean has(int id) {
return repo.has(id);
}
public List<Task> search(String query) {
return repo.findAll().stream()
.filter(task -> ((SimpleTask) task).data().title().contains(query))
.toList(); .toList();
} }
} }