introduced ModuleRegistry to easy inter-module dependencies
This commit is contained in:
@@ -14,6 +14,7 @@ import de.srsoftware.configuration.Configuration;
|
||||
import de.srsoftware.tools.Path;
|
||||
import de.srsoftware.tools.SessionToken;
|
||||
import de.srsoftware.umbrella.core.BaseHandler;
|
||||
import de.srsoftware.umbrella.core.ModuleRegistry;
|
||||
import de.srsoftware.umbrella.core.api.*;
|
||||
import de.srsoftware.umbrella.core.exceptions.UmbrellaException;
|
||||
import de.srsoftware.umbrella.core.model.*;
|
||||
@@ -25,27 +26,23 @@ public class TimeModule extends BaseHandler implements TimeService {
|
||||
|
||||
private class ExtendedTime extends Time{
|
||||
|
||||
private final Collection<Task> tasks;
|
||||
|
||||
private final Collection<Task> tasks;
|
||||
public ExtendedTime(long id, long userId, String subject, String description, LocalDateTime start, LocalDateTime end, State state, Collection<Task> tasks) {
|
||||
super(id, userId, subject, description, start, end, state, tasks.stream().map(Task::id).toList());
|
||||
this.tasks = tasks;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private final UserService users;
|
||||
private final ModuleRegistry registry;
|
||||
private final TimeDb timeDb;
|
||||
private final TaskService tasks;
|
||||
private final CompanyService companies;
|
||||
private final ProjectService projects;
|
||||
|
||||
public TimeModule(Configuration config, TaskService taskService) throws UmbrellaException {
|
||||
companies = taskService.companyService();
|
||||
projects = taskService.projectService();
|
||||
tasks = taskService;
|
||||
users = tasks.userService();
|
||||
|
||||
public TimeModule(ModuleRegistry registry, Configuration config) throws UmbrellaException {
|
||||
var dbFile = config.get(CONFIG_DATABASE).orElseThrow(() -> missingFieldException(CONFIG_DATABASE));
|
||||
timeDb = new SqliteDb(connect(dbFile));
|
||||
this.registry = registry.add(this);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -53,7 +50,7 @@ public class TimeModule extends BaseHandler implements TimeService {
|
||||
addCors(ex);
|
||||
try {
|
||||
Optional<Token> token = SessionToken.from(ex).map(Token::of);
|
||||
var user = users.loadUser(token);
|
||||
var user = registry.userService().loadUser(token);
|
||||
if (user.isEmpty()) return unauthorized(ex);
|
||||
var head = path.pop();
|
||||
return switch (head) {
|
||||
@@ -109,11 +106,11 @@ public class TimeModule extends BaseHandler implements TimeService {
|
||||
var json = json(ex);
|
||||
if (!(json.has(COMPANY_ID) && json.get(COMPANY_ID) instanceof Number cid)) throw missingFieldException(COMPANY_ID);
|
||||
var companyId = cid.longValue();
|
||||
var company = companies.get(companyId);
|
||||
if (!companies.membership(companyId,user.id())) throw forbidden("You are mot a member of company {0}",company.name());
|
||||
var company = registry.companyService().get(companyId);
|
||||
if (!registry.companyService().membership(companyId,user.id())) throw forbidden("You are mot a member of company {0}",company.name());
|
||||
if (!(json.has(PROJECT_ID) && json.get(PROJECT_ID) instanceof Number pid)) throw missingFieldException(PROJECT_ID);
|
||||
long projectId = pid.longValue();
|
||||
Map<Long,Task> tasksOfProject = tasks.listProjectTasks(projectId);
|
||||
Map<Long,Task> tasksOfProject = registry.taskService().listProjectTasks(projectId);
|
||||
|
||||
List<Map<String, Object>> times = timeDb.listTimes(tasksOfProject.keySet())
|
||||
.stream().filter(not(Time::isClosed))
|
||||
|
||||
Reference in New Issue
Block a user