All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.dd4t.providers.impl.BrokerTaxonomyProvider Maven / Gradle / Ivy

There is a newer version: 2.1.12
Show newest version
/*
 * Copyright (c) 2015 SDL, Radagio & R. Oudshoorn
 *
 * 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 org.dd4t.providers.impl;

import com.tridion.broker.StorageException;
import com.tridion.storage.RelatedKeyword;
import com.tridion.storage.StorageManagerFactory;
import com.tridion.storage.StorageTypeMapping;
import com.tridion.storage.dao.BaseDAO;
import com.tridion.storage.dao.WrappableDAO;
import com.tridion.storage.persistence.JPABaseDAO;
import com.tridion.taxonomies.Keyword;
import com.tridion.taxonomies.TaxonomyFactory;
import com.tridion.util.TCMURI;
import org.dd4t.core.exceptions.ItemNotFoundException;
import org.dd4t.core.exceptions.NotImplementedException;
import org.dd4t.core.exceptions.SerializationException;
import org.dd4t.providers.BaseBrokerProvider;
import org.dd4t.providers.TaxonomyProvider;

import java.text.ParseException;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * Provides access to taxonomies published to a Content Delivery database. It returns keywords with all their parent/
 * children relationships resolved. It also provides the capability to retrieve related items (i.e. Tridion items that
 * use each Keyword in the taxonomy directly).
 * 

* TODO: Proper interface (same for client and service) * TODO: Proper overrides * TODO: decompress * * @author Mihai Cadariu */ public class BrokerTaxonomyProvider extends BaseBrokerProvider implements TaxonomyProvider { private static final String SELECT_RELATED_KEYWORDS = "select distinct(rk) from RelatedKeyword rk, ItemMeta im" + " where rk.publicationId = :publicationId and rk.taxonomyId = :taxonomyId and im.itemType = :itemType and" + " rk.itemId = im.itemId and rk.publicationId = im.publicationId"; private static final String SELECT_RELATED_COMPONENTS_BY_SCHEMA = "select distinct(rk) from RelatedKeyword rk, " + "ItemMeta im, ComponentMeta cm" + " where rk.publicationId = :publicationId and rk.taxonomyId = " + ":taxonomyId and im.itemType = 16 and rk.itemId = im.itemId and rk.publicationId = im.publicationId and" + " cm.publicationId = im.publicationId and cm.itemId = im.itemId and cm.schemaId = :schemaId"; /** * Retrieves the Keyword object model with all its Parent/Children relationships resloved. * * @param taxonomyURI String representing the taxonomy TCMURI * @return Keyword the resolved taxonomy with its parent/children relationships * @throws StorageException if something went wrong during accessing the CD DB */ public Keyword getTaxonomy(String taxonomyURI) throws StorageException { TaxonomyFactory factory = new TaxonomyFactory(); return factory.getTaxonomyKeywords(taxonomyURI); } /** * Returns a list of RelatedKeyword objects representing the usage of each Keyword under the given taxonomy URI * and its direct using item. Returned items are only of the given type. * * @param taxonomyURI String representing the root taxonomy Keyword TCMURI * @param itemType int representing the item type id to retrieve * @return List a list of RelatedKeyword objects holding item usage information * @throws ParseException if the given Keyword URI does not represent a valid TCMURI * @throws StorageException if something went wrong during accessing the CD DB */ public List getRelatedItems(String taxonomyURI, int itemType) throws ParseException, StorageException { TCMURI taxonomyTcmUri = new TCMURI(taxonomyURI); int publicationId = taxonomyTcmUri.getPublicationId(); Map queryParams = new HashMap<>(); queryParams.put("publicationId", publicationId); queryParams.put("taxonomyId", taxonomyTcmUri.getItemId()); queryParams.put("itemType", itemType); return getJPADAO(publicationId).executeQueryListResult(SELECT_RELATED_KEYWORDS, queryParams); } /** * Returns a list of RelatedKeyword objects representing the usage of each Keyword under the given taxonomy URI * and its direct using item. Returned items are only Components based on the given Schema URI. * * @param taxonomyURI String representing the root taxonomy Keyword TCMURI * @param schemaURI String representing the filter for classified related Components to return for each Keyword * @return List a list of RelatedKeyword objects holding item usage information * @throws ParseException if the given Keyword URI does not represent a valid TCMURI * @throws StorageException if something went wrong during accessing the CD DB */ public List getRelatedComponentsBySchema(String taxonomyURI, String schemaURI) throws ParseException, StorageException { TCMURI taxonomyTcmUri = new TCMURI(taxonomyURI); TCMURI schemaTcmUri = new TCMURI(schemaURI); int publicationId = taxonomyTcmUri.getPublicationId(); Map queryParams = new HashMap<>(); queryParams.put("publicationId", publicationId); queryParams.put("taxonomyId", taxonomyTcmUri.getItemId()); queryParams.put("schemaId", schemaTcmUri.getItemId()); return getJPADAO(publicationId).executeQueryListResult(SELECT_RELATED_COMPONENTS_BY_SCHEMA, queryParams); } /* Looks for the JPABaseDAO defined in the storage config. If XPM wrappers are used, it searches inside the wrapper. */ private JPABaseDAO getJPADAO(int publicationId) throws StorageException { BaseDAO baseDAO = StorageManagerFactory.getDAO(publicationId, StorageTypeMapping.ITEM_META); boolean loop = true; while (loop) { if (baseDAO instanceof WrappableDAO) { WrappableDAO wrappableDAO = (WrappableDAO) baseDAO; baseDAO = wrappableDAO.getWrapped(); } else { loop = false; } if (baseDAO instanceof JPABaseDAO) { return (JPABaseDAO) baseDAO; } } throw new StorageException("Cannot find JPABaseDAO. Please check your storage bindings."); } @Override public String getTaxonomyByURI(final String taxonomyURI, final boolean resolveContent) throws ItemNotFoundException, SerializationException { throw new NotImplementedException(); } @Override public String getTaxonomyFilterBySchema(final String taxonomyURI, final String schemaURI) throws ItemNotFoundException, SerializationException { throw new NotImplementedException(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy