/*
* This file is part of the OpenNMS(R) Application.
*
* OpenNMS(R) is Copyright (C) 2011 The OpenNMS Group, Inc. All rights reserved.
* OpenNMS(R) is a derivative work, containing both original code, included code and modified
* code that was published under the GNU General Public License. Copyrights for modified
* and included code are below.
*
* OpenNMS(R) is a registered trademark of The OpenNMS Group, Inc.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*
* For more information contact:
* OpenNMS Licensing <license@opennms.org>
* http://www.opennms.org/
* http://www.opennms.com/
*/
package org.opennms.netmgt.dao.support;
import org.opennms.netmgt.dao.OnmsDao;
import org.springframework.transaction.PlatformTransactionManager;
/**
* Template for creating a row if and only if one doesn't already exists. This suffers
* from some of the same concurrency issues as described in the {@link UpsertTemplate}. See the
* detailed javadoc there for a description.
*
* @author brozow
*/
public abstract class CreateIfNecessaryTemplate<T, D extends OnmsDao<T, ?>> extends UpsertTemplate<T, D> {
/**
* Create a CreateIfNecessaryTemplate using the given transactionManager to create transactions.
*/
public CreateIfNecessaryTemplate(PlatformTransactionManager transactionManager, D dao) {
super(transactionManager, dao);
}
@Override
abstract protected T query();
/**
* There is no need to update the object for this case as we just return the object found.
*/
@Override
protected T doUpdate(T dbObj) {
return dbObj;
}
@Override
abstract protected T doInsert();
}