/* * Copyright (C) 2015 LibreCCM Foundation. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, * MA 02110-1301 USA */ package org.librecms.contentsection; import org.hibernate.envers.Audited; import org.libreccm.categorization.Categorization; import org.libreccm.core.CcmObject; import org.libreccm.l10n.LocalizedString; import org.librecms.CmsConstants; import org.librecms.contentsection.privileges.AssetPrivileges; import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.Objects; import java.util.Optional; import javax.persistence.AssociationOverride; import javax.persistence.Embedded; import javax.persistence.Entity; import javax.persistence.Inheritance; import javax.persistence.InheritanceType; import javax.persistence.JoinColumn; import javax.persistence.JoinTable; import javax.persistence.NamedQueries; import javax.persistence.NamedQuery; import javax.persistence.OneToMany; import javax.persistence.OrderBy; import javax.persistence.Table; import static org.librecms.CmsConstants.*; /** * Base class for all assets providing common fields. This class is * not indented for direct use. Only to sub classes should be * used. * * @author Jens Pelzetter */ @Entity @Table(schema = DB_SCHEMA, name = "ASSETS") @Inheritance(strategy = InheritanceType.JOINED) @Audited @NamedQueries({ @NamedQuery( name = "Asset.findById", query = "SELECT DISTINCT a " + "FROM Asset a " + "LEFT JOIN a.permissions p " + "WHERE a.objectId = :assetId " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ")" ) , @NamedQuery( name = "Asset.findByIdAndType", query = "SELECT DISTINCT a " + "FROM Asset a " + "LEFT JOIN a.permissions p " + "WHERE a.objectId = :assetId " + "AND TYPE(a) = :type " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " )" + " OR true = :isSystemUser OR true = :isAdmin" + ")" ) , @NamedQuery( name = "Asset.findByUuid", query = "SELECT DISTINCT a " + "FROM Asset a " + "LEFT JOIN a.permissions p " + "WHERE a.uuid = :uuid " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ")") , @NamedQuery( name = "Asset.findByType", query = "SELECT DISTINCT a " + "FROM Asset a " + "LEFT JOIN a.permissions p " + "WHERE TYPE(a) = :type " + "AND a.categories IS NOT EMPTY " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ") " + "ORDER BY a.displayName") , @NamedQuery( name = "Asset.findByTypeAndContentSection", query = "SELECT DISTINCT a " + "FROM Asset a " + "JOIN a.categories c " + "LEFT JOIN a.permissions p " + "WHERE TYPE(a) = :type " + "AND c.category.section = :section " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ")") , @NamedQuery( name = "Asset.findByUuidAndType", query = "SELECT DISTINCT a " + "FROM Asset a " + "LEFT JOIN a.permissions p " + "WHERE a.uuid = :uuid " + "AND TYPE(a) = :type " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ")") , @NamedQuery( name = "Asset.findByContentSection", query = "SELECT DISTINCT a " + "FROM Asset a " + "JOIN a.categories c " + "LEFT JOIN a.permissions p " + "WHERE c.category.section = :section " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ")") , @NamedQuery( name = "Asset.findByTitle'", query = "SELECT DISTINCT a " + "FROM Asset a " + "JOIN a.title.values t " + "LEFT JOIN a.permissions p " + "WHERE LOWER(t) LIKE CONCAT('%', :title, '%') " + "AND a.categories IS NOT EMPTY " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ")") , @NamedQuery( name = "Asset.findByTitleAndContentSection", query = "SELECT DISTINCT a " + "FROM Asset a " + "JOIN a.title.values t " + "JOIN a.categories c " + "LEFT JOIN a.permissions p " + "WHERE LOWER(t) LIKE CONCAT('%', :title, '%') " + "AND c.category.section = :section " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ")") , @NamedQuery( name = "Asset.findByTitleAndType", query = "SELECT DISTINCT a " + "FROM Asset a " + "JOIN a.title.values t " + "LEFT JOIN a.permissions p " + "WHERE LOWER(t) LIKE CONCAT('%', :title, '%') " + "AND TYPE(a) = :type " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ")") , @NamedQuery( name = "Asset.findByTitleAndTypeAndContentSection", query = "SELECT DISTINCT a " + "FROM Asset a " + "JOIN a.title.values t " + "JOIN a.categories c " + "LEFT JOIN a.permissions p " + "WHERE LOWER(t) LIKE CONCAT('%', :title, '%') " + "AND TYPE(a) = :type " + "AND c.category.section = :section " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ")") , @NamedQuery( name = "Asset.findByFolder", query = "SELECT DISTINCT a " + "FROM Asset a " + "JOIN a.categories c " + "LEFT JOIN a.permissions p " + "WHERE c.category = :folder " + "AND c.type = '" + CATEGORIZATION_TYPE_FOLDER + "' " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ")") , @NamedQuery( name = "Asset.findByNameInFolder", query = "SELECT DISTINCT a " + "FROM Asset a " + "JOIN a.categories c " + "LEFT JOIN a.permissions p " + "WHERE c.category = :folder " + "AND c.type = '" + CATEGORIZATION_TYPE_FOLDER + "' " + "AND a.displayName = :name " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = '" + AssetPrivileges.VIEW + "'" + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + " )" ) , @NamedQuery( name = "Asset.countInFolder", query = "SELECT COUNT(DISTINCT a) " + "FROM Asset a " + "JOIN a.categories c " + "LEFT JOIN a.permissions p " + "WHERE c.category = :folder " + "AND c.type = '" + CATEGORIZATION_TYPE_FOLDER + "' " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ")") , @NamedQuery( name = "Asset.filterByFolderAndTitle", query = "SELECT DISTINCT a " + "FROM Asset a " + "JOIN a.categories c " + "JOIN a.title.values t " + "LEFT JOIN a.permissions p " + "WHERE c.category = :folder " + "AND c.type = '" + CATEGORIZATION_TYPE_FOLDER + "' " + "AND LOWER(t) LIKE CONCAT('%', LOWER(:title), '%') " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ")") , @NamedQuery( name = "Asset.countFilterByFolderAndTitle", query = "SELECT COUNT(DISTINCT a) " + "FROM Asset a " + "JOIN a.categories c " + "JOIN a.title.values t " + "LEFT JOIN a.permissions p " + "WHERE c.category = :folder " + "AND c.type = '" + CATEGORIZATION_TYPE_FOLDER + "' " + "AND LOWER(t) LIKE CONCAT('%', LOWER(:title), '%') " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ")") , @NamedQuery( name = "Asset.filterByFolderAndType", query = "SELECT DISTINCT a " + "FROM Asset a " + "JOIN a.categories c " + "LEFT JOIN a.permissions p " + "WHERE c.category = :folder " + "AND c.type = '" + CATEGORIZATION_TYPE_FOLDER + "' " + "AND TYPE(a) = :type " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ") " + "ORDER BY a.displayName") , @NamedQuery( name = "Asset.countFilterByFolderAndType", query = "SELECT COUNT(DISTINCT a) " + "FROM Asset a " + "JOIN a.categories c " + "LEFT JOIN a.permissions p " + "WHERE c.category = :folder " + "AND c.type = '" + CATEGORIZATION_TYPE_FOLDER + "' " + "AND TYPE(a) = :type " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ")") , @NamedQuery( name = "Asset.filterByFolderAndTitleAndType", query = "SELECT DISTINCT a " + "FROM Asset a " + "JOIN a.title.values t " + "JOIN a.categories c " + "LEFT JOIN a.permissions p " + "WHERE c.category = :folder " + "AND c.type = '" + CATEGORIZATION_TYPE_FOLDER + "' " + "AND LOWER(t) LIKE CONCAT('%', LOWER(:title), '%') " + "AND TYPE(a) = :type " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ")") , @NamedQuery( name = "Asset.countFilterByFolderAndTitleAndType", query = "SELECT COUNT(DISTINCT a) " + "FROM Asset a " + "JOIN a.categories c " + "JOIN a.title.values t " + "LEFT JOIN a.permissions p " + "WHERE c.category = :folder " + "AND c.type = '" + CATEGORIZATION_TYPE_FOLDER + "' " + "AND LOWER(t) LIKE CONCAT('%', LOWER(:title), '%') " + "AND TYPE(a) = :type " + "AND (" + " (" + " p.grantee IN :roles " + " AND p.grantedPrivilege = " + " '" + AssetPrivileges.VIEW + "' " + " ) " + " OR true = :isSystemUser OR true = :isAdmin" + ")") }) public class Asset extends CcmObject { private static final long serialVersionUID = -3499741368562653529L; @OneToMany(mappedBy = "asset") @OrderBy("sortKey ASC") private List> itemAttachments; @Embedded @AssociationOverride( name = "values", joinTable = @JoinTable(name = "ASSET_TITLES", schema = DB_SCHEMA, joinColumns = { @JoinColumn(name = "ASSET_ID") } ) ) private LocalizedString title; public Asset() { title = new LocalizedString(); itemAttachments = new ArrayList<>(); } public LocalizedString getTitle() { return title; } public void setTitle(final LocalizedString title) { Objects.requireNonNull(title); this.title = title; } public List> getItemAttachments() { if (itemAttachments == null) { return new ArrayList<>(); } else { return Collections.unmodifiableList(itemAttachments); } } protected void setItemAttachments( final List> itemAttachments) { if (itemAttachments == null) { this.itemAttachments = new ArrayList<>(); } else { this.itemAttachments = itemAttachments; } } protected void addItemAttachment(final ItemAttachment itemAttachment) { itemAttachments.add(itemAttachment); } protected void removeItemAttachment(final ItemAttachment itemAttachment) { itemAttachments.remove(itemAttachment); } private Optional getFolder() { final Optional result = getCategories() .stream() .filter(categorization -> CmsConstants.CATEGORIZATION_TYPE_FOLDER. equals(categorization.getType())) .findFirst(); if (result.isPresent()) { return Optional.of(result.get().getCategory()); } else { return Optional.empty(); } } @Override public int hashCode() { int hash = super.hashCode(); hash = 97 * hash + Objects.hashCode(title); return hash; } @Override public boolean equals(final Object obj) { if (this == obj) { return true; } if (!super.equals(obj)) { return false; } if (obj == null) { return false; } if (!(obj instanceof Asset)) { return false; } final Asset other = (Asset) obj; if (!other.canEqual(this)) { return false; } return Objects.equals(title, other.getTitle()); } @Override public boolean canEqual(final Object obj) { return obj instanceof Asset; } @Override public String toString(final String data) { return super.toString(String.format(", title = \"%s\"%s", title, data)); } }