/*
* RHQ Management Platform
* Copyright (C) 2005-2008 Red Hat, Inc.
* All rights reserved.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License, version 2, as
* published by the Free Software Foundation, and/or the GNU Lesser
* General Public License, version 2.1, also as published by the Free
* Software Foundation.
*
* 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 and the GNU Lesser General Public License
* for more details.
*
* You should have received a copy of the GNU General Public License
* and the GNU Lesser General Public License along with this program;
* if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
package org.rhq.core.domain.configuration;
import javax.persistence.CascadeType;
import javax.persistence.DiscriminatorValue;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.NamedQueries;
import javax.persistence.NamedQuery;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlTransient;
import org.rhq.core.domain.configuration.group.AbstractGroupConfigurationUpdate;
import org.rhq.core.domain.configuration.group.GroupPluginConfigurationUpdate;
import org.rhq.core.domain.resource.Resource;
@DiscriminatorValue("plugin")
@Entity
@NamedQueries( {
@NamedQuery(name = PluginConfigurationUpdate.QUERY_FIND_ALL_IN_STATUS, query = "" //
+ "SELECT cu " //
+ " FROM PluginConfigurationUpdate cu "),
@NamedQuery(name = PluginConfigurationUpdate.QUERY_FIND_ALL_BY_RESOURCE_ID, query = "" //
+ "SELECT cu " //
+ " FROM PluginConfigurationUpdate cu " //
+ " WHERE cu.resource.id = :resourceId " //
+ " AND ( cu.createdTime > :startTime OR :startTime IS NULL ) " //
+ " AND ( cu.modifiedTime < :endTime OR :endTime IS NULL ) "),
@NamedQuery(name = PluginConfigurationUpdate.QUERY_FIND_CURRENTLY_ACTIVE_CONFIG, query = "" //
+ "SELECT cu " //
+ " FROM PluginConfigurationUpdate cu " //
+ " WHERE cu.resource.id = :resourceId " //
+ " AND cu.status <> 'INPROGRESS' " //
+ " AND cu.modifiedTime = ( SELECT MAX(cu2.modifiedTime) " //
+ " FROM PluginConfigurationUpdate cu2 " //
+ " WHERE cu2.resource.id = :resourceId " //
+ " AND cu2.status <> 'INPROGRESS') "),
@NamedQuery(name = PluginConfigurationUpdate.QUERY_FIND_LATEST_BY_RESOURCE_ID, query = "" //
+ "SELECT cu " //
+ " FROM PluginConfigurationUpdate cu " //
+ " WHERE cu.resource.id = :resourceId " //
+ " AND cu.modifiedTime = ( SELECT MAX(cu2.modifiedTime) " //
+ " FROM PluginConfigurationUpdate cu2 " //
+ " WHERE cu2.resource.id = :resourceId) "),
@NamedQuery(name = PluginConfigurationUpdate.QUERY_FIND_BY_GROUP_ID_AND_STATUS, query = "" //
+ "SELECT cu " //
+ " FROM PluginConfigurationUpdate cu JOIN cu.resource.explicitGroups rg " //
+ " WHERE rg.id = :groupId " //
+ " AND cu.status = :status"),
@NamedQuery(name = PluginConfigurationUpdate.QUERY_FIND_COMPOSITE_BY_PARENT_UPDATE_ID, query = "" //
+ "SELECT new org.rhq.core.domain.configuration.composite.ConfigurationUpdateComposite" //
+ " ( cu.id, cu.status, cu.errorMessage, cu.subjectName, cu.createdTime, cu.modifiedTime, " // update w/o config
+ " res.id, res.name ) " //
+ " FROM PluginConfigurationUpdate cu " //
+ " JOIN cu.resource res " //
+ " WHERE cu.groupConfigurationUpdate.id = :groupConfigurationUpdateId"),
@NamedQuery(name = PluginConfigurationUpdate.QUERY_FIND_BY_PARENT_UPDATE_ID, query = "" //
+ "SELECT cu.id " //
+ " FROM PluginConfigurationUpdate cu " //
+ " WHERE cu.groupConfigurationUpdate.id = :groupConfigurationUpdateId"),
@NamedQuery(name = PluginConfigurationUpdate.QUERY_FIND_STATUS_BY_PARENT_UPDATE_ID, query = "" //
+ "SELECT cu.status " //
+ " FROM PluginConfigurationUpdate cu " //
+ " WHERE cu.groupConfigurationUpdate.id = :groupConfigurationUpdateId " //
+ " GROUP BY cu.status"), //
@NamedQuery(name = PluginConfigurationUpdate.QUERY_DELETE_BY_RESOURCES_0, query = "" //
+ "UPDATE Property p " //
+ " SET p.parentMap = NULL, " //
+ " p.parentList = NULL " //
+ " WHERE p.configuration IN ( SELECT pcu.configuration " //
+ " FROM PluginConfigurationUpdate pcu " //
+ " WHERE pcu.resource.id IN ( :resourceIds ) " //
+ " AND NOT pcu.configuration = pcu.resource.pluginConfiguration )"),
@NamedQuery(name = PluginConfigurationUpdate.QUERY_DELETE_BY_RESOURCES_1, query = "" //
+ "DELETE FROM RawConfiguration rc " //
+ " WHERE rc.configuration IN ( SELECT pcu.configuration " //
+ " FROM PluginConfigurationUpdate pcu " //
+ " WHERE pcu.resource.id IN ( :resourceIds ) " //
+ " AND NOT pcu.configuration = pcu.resource.resourceConfiguration )"),
@NamedQuery(name = PluginConfigurationUpdate.QUERY_DELETE_BY_RESOURCES_2, query = "" //
+ "DELETE FROM Configuration c " //
+ " WHERE c IN ( SELECT pcu.configuration " //
+ " FROM PluginConfigurationUpdate pcu " //
+ " WHERE pcu.resource.id IN ( :resourceIds ) " //
+ " AND NOT pcu.configuration = pcu.resource.pluginConfiguration )"),
@NamedQuery(name = PluginConfigurationUpdate.QUERY_DELETE_BY_RESOURCES_3, query = "" //
+ "DELETE FROM PluginConfigurationUpdate pcu " //
+ " WHERE pcu.resource.id IN ( :resourceIds )"),
@NamedQuery(name = PluginConfigurationUpdate.QUERY_DELETE_GROUP_UPDATES_FOR_GROUP, query = "" //
+ "UPDATE PluginConfigurationUpdate pcu " //
+ " SET pcu.groupConfigurationUpdate = null " //
+ " WHERE pcu.groupConfigurationUpdate IN ( SELECT apcu " //
+ " FROM GroupPluginConfigurationUpdate apcu " //
+ " WHERE apcu.group.id = :groupId )"),
@NamedQuery(name = PluginConfigurationUpdate.QUERY_DELETE_GROUP_UPDATE, query = "" //
+ "UPDATE PluginConfigurationUpdate pcu " //
+ " SET pcu.groupConfigurationUpdate = null " //
+ " WHERE pcu.groupConfigurationUpdate IN ( SELECT apcu " //
+ " FROM GroupPluginConfigurationUpdate apcu " //
+ " WHERE apcu.id = :apcuId )") })
/**
* @author Joseph Marques
*/
@XmlAccessorType(XmlAccessType.FIELD)
public class PluginConfigurationUpdate extends AbstractResourceConfigurationUpdate {
private static final long serialVersionUID = 1L;
public static final String QUERY_FIND_ALL_IN_STATUS = "PluginConfigurationUpdate.findAllInStatus";
public static final String QUERY_FIND_ALL_BY_RESOURCE_ID = "PluginConfigurationUpdate.findAllByResourceId";
public static final String QUERY_FIND_CURRENTLY_ACTIVE_CONFIG = "PluginConfigurationUpdate.findCurrentlyActiveConfig";
public static final String QUERY_FIND_LATEST_BY_RESOURCE_ID = "PluginConfigurationUpdate.findLatestByResourceId";
public static final String QUERY_FIND_COMPOSITE_BY_PARENT_UPDATE_ID = "PluginConfigurationUpdate.findCompositeByParentUpdateId";
public static final String QUERY_FIND_BY_PARENT_UPDATE_ID = "PluginConfigurationUpdate.findByParentUpdateId";
public static final String QUERY_FIND_STATUS_BY_PARENT_UPDATE_ID = "PluginConfigurationUpdate.findStatusByParentUpdateId";
public static final String QUERY_FIND_BY_GROUP_ID_AND_STATUS = "PluginConfigurationUpdate.findByGroupIdAndStatus";
public static final String QUERY_DELETE_BY_RESOURCES_0 = "PluginConfigurationUpdate.deleteByResources0";
public static final String QUERY_DELETE_BY_RESOURCES_1 = "PluginConfigurationUpdate.deleteByResources1";
public static final String QUERY_DELETE_BY_RESOURCES_2 = "PluginConfigurationUpdate.deleteByResources2";
public static final String QUERY_DELETE_BY_RESOURCES_3 = "PluginConfigurationUpdate.deleteByResources3";
public static final String QUERY_DELETE_GROUP_UPDATES_FOR_GROUP = "pluginConfigurationUpdate.deleteGroupUpdatesForGroup";
public static final String QUERY_DELETE_GROUP_UPDATE = "pluginConfigurationUpdate.deleteGroupUpdate";
@JoinColumn(name = "PLUGIN_CONFIG_RES_ID", referencedColumnName = "ID", nullable = true)
@ManyToOne(cascade = CascadeType.MERGE, fetch = FetchType.LAZY, optional = true)
@XmlTransient
private Resource resource;
@JoinColumn(name = "AGG_PLUGIN_UPDATE_ID", referencedColumnName = "ID", nullable = true)
@ManyToOne(optional = true)
private GroupPluginConfigurationUpdate groupConfigurationUpdate;
protected PluginConfigurationUpdate() {
} // JPA
public PluginConfigurationUpdate(Resource resource, Configuration config, String subjectName) {
super(config, subjectName);
this.resource = resource;
}
@Override
public Resource getResource() {
return resource;
}
public void setResource(Resource resource) {
this.resource = resource;
}
@Override
public AbstractGroupConfigurationUpdate getAbstractGroupConfigurationUpdate() {
return getGroupConfigurationUpdate();
}
public GroupPluginConfigurationUpdate getGroupConfigurationUpdate() {
return groupConfigurationUpdate;
}
public void setGroupConfigurationUpdate(GroupPluginConfigurationUpdate groupConfigurationUpdate) {
this.groupConfigurationUpdate = groupConfigurationUpdate;
}
@Override
protected void appendToStringInternals(StringBuilder str) {
super.appendToStringInternals(str);
str.append(", resource=").append(this.resource);
if (groupConfigurationUpdate != null) {
// circular toString if you try to print the entire groupConfigurationUpdate object
str.append(", groupPluginConfigurationUpdate=").append(groupConfigurationUpdate.getId());
}
}
}