/* * Copyright [2014] [Christian Loehnert, krampenschiesser@gmail.com] * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package de.ks.idnadrev.task.fasttrack; import de.ks.datasource.NewInstanceDataSource; import de.ks.idnadrev.entity.Task; import de.ks.persistence.PersistentWork; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import java.util.function.Consumer; public class FastTrackDS extends NewInstanceDataSource<Task> { private static final Logger log = LoggerFactory.getLogger(FastTrackDS.class); public FastTrackDS() { super(Task.class); } @Override public Task loadModel(Consumer<Task> furtherProcessing) { Task task = super.loadModel(furtherProcessing); furtherProcessing.accept(task); return task; } @Override public void saveModel(Task model, Consumer<Task> beforeSaving) { PersistentWork.run(em -> { String name = model.getName(); Task task = name == null ? null : PersistentWork.forName(Task.class, name); if (task != null) { log.debug("Found existing task {}", task); beforeSaving.accept(task); } else { if (model != null) { beforeSaving.accept(model); if (model.getName() != null && model.getName().length() > 0) { em.persist(model); log.debug("Creating new task {}", model); } } } }); } }