close

Filter

loading table of contents...

Blueprint Developer Manual / Version 2412.0

Table Of Contents

5.3.3.2 Taxonomy Assignment

To enable tagging of content two properties are available the CMLinkable content type.

subjectTaxonomy
Type Link list
Description Subject(s) / topic(s) of that content item
locationTaxonomy
Type Link list
Description Geographic location(s) of that content item

Table 5.8. CMLinkable Properties for Tagging


Editors can assign taxonomies to content items using CoreMedia Studio and the Blueprint taxonomy property editor. It allows for the following:

  • adding/removing references to taxonomy

  • autocompletion

  • suggestions

Taxonomy Property Editor

Figure 5.6. Taxonomy Property Editor


The user can add taxonomy keywords to the corresponding property link list using the taxonomy property editor. The editor also provides suggestions that are provided by a name matching algorithm. The strategy type can be configured in the preferences dialog of CoreMedia Studio.

Taxonomy Studio Settings

Figure 5.7. Taxonomy Studio Settings


How taxonomies are loaded

A Blueprint taxonomy tree is built through content items located in a specific folder of the content repository. The default taxonomy resolver will then look for a "_root" settings content item inside these folders and uses the taxonomy content items linked inside the LinkListProperty "roots" as top level nodes. If the "_root" content item is not found, the taxonomy resolver checks for empty referrers of all taxonomy content items inside a taxonomy folder, to determine which node is a top level node of the given taxonomy tree. In that case, top level node content items must be placed directly within the root folder. Taxonomies of subsequent levels can also be placed in subfolders. The name of the folder in which the taxonomy tree is placed defines the name of the taxonomy tree and is visible as a root node in the taxonomy administration UI.

The lookup folders for taxonomies and the strategy used to build the tree are configured in the Spring configuration class TaxonomyConfiguration of the shared/taxonomies module. The bean properties

siteConfigPath

and

globalConfigPath

of the strategyResolver bean configure the folders that are used to find taxonomies. TaxonomyResolverImpl implements the TaxonomyResolver interface so that it is possible to implement other taxonomy detection strategies.

Warning

Warning

The default taxonomy implementation (DefaultTaxonomy.java) checks the taxonomy folder for write permissions. If these permissions are not granted, the taxonomy won't appear in Studio. Therefore, ensure that taxonomy administrators have Folder rights for taxonomy folders.

How to implement a new taxonomy resolver strategy

The TaxonomyResolverImpl implements the interface TaxonomyResolver and is injected to the TaxonomyResource in the component-taxonomies.xml. For every taxonomy request, the TaxonomyResource instance looks up the corresponding Taxonomy object using the resolver instance. To change the resolver strategy, inject another instance of TaxonomyResolver to the TaxonomyResource.

How to configure the content properties used for semantic strategies

The content properties that are used for a semantic evaluation are configured in the method SemanticTaxonomyConfiguration#semanticDocumentProperties of the shared/taxonomies module. The Spring configuration declares the abstract class AbstractSemanticService that new semantic service can extend from. The default properties used for a semantic suggestion search are:

  • title

  • teaserTitle

  • detailText

  • teaserText

How to implement a new suggestion/semantic strategy

To add a new semantic strategy to Studio, it is necessary to implement the corresponding strategy for it and add it to CoreMedia Studio.

A new semantic strategy can easily be created by implementing the interface SemanticStrategy. The result of a strategy is a Suggestions instance with several Suggestion instances in it. Each Suggestion instance must have a corresponding content instance in the repository whose content type matches that one used for the taxonomy. Blueprint uses CMTaxonomy content items for keywords of a taxonomy, so suggestions must be fed with these content items. Additionally, a float value weight can be set for each suggestion, describing how exactly the keyword matches from 0 to 1. After implementing the semantic strategy, the implementing class must be added to the Spring configuration, for example:

<customize:append id="semanticStrategyExamplesCustomizer" bean="semanticServiceStrategies" order="1000">
      <list>
      <ref bean="myMatching"/>
      </list>
      </customize:append>

Next, the new suggestion strategy must to be added to Studio, so that is selectable in CoreMedia Studio.

  1. Open the file TaxonomyStudioPlugin.ts

  2. Add an entry to the configuration section that configures the AddTaggingStrategyPlugin:

    <taxonomy:AddTaggingStrategyPlugin serviceId="{TAXONOMY_NAME_MATCHING_KEY}" label="{resourceManager.getString('com.coremedia.blueprint.studio.taxonomy.TaxonomyStudioPlugin', 'TaxonomyPreferences_value_nameMatching_text')}" />

    Make sure that the serviceId matches the one you configured for the implementation of the SemanticStrategy.

How to add a site specific taxonomy

The logic how a site-depending taxonomy tree is resolved, is implemented in the TaxonomyResolver#getTaxonomy(String siteId, String taxonomyId) method.

To create a new site-depending taxonomy proceed as follows:

  1. Open Studio, create and select the site specific folder Options/Taxonomies/ from the library.

  2. Create a new sub folder with the name of the new taxonomy.

    The location for the new taxonomy has been created now.

  3. To identify the type of taxonomy (such as CMTaxonomy or CMLocTaxonomy) you have to create at least one taxonomy content item in the new folder. Alternatively, create a _root settings content item and link a newly created CMTaxonomy content item to the StructList roots to it.

Once the taxonomy has been set up, additional nodes can be created using the taxonomy manager. If the new taxonomy does not appear as new element in the column on the left, press the reload button. It ensures that the TaxonomyResolver rebuilds the list of available taxonomy trees. The new taxonomy is shown in the root column afterwards, include the site name it is created in.

Creating site specific taxonomies allows you to overwrite existing ones. For example, you create a new taxonomy tree called Subject for site X and open an article that is located in a sub folder of site X, the regular Subject taxonomy property editor on the Taxonomies tab in CoreMedia Studio will access the Subject taxonomy of your new site, not the one that is located in the global Settings folders. The suggestions and the chooser dialog will also work in the new taxonomy tree.

How to configure the taxonomy property editor for a taxonomy

CoreMedia Blueprint comes with two types of taxonomies: Subject and Location. The name of the taxonomy matches the folder name they are located in, which is /Settings/Taxonomies. When the taxonomy property editor for a Studio form is configured, these IDs are passed to the property editor, for example

<taxonomy:taxonomyPropertyField propertyName="subjectTaxonomy"
                                                    taxonomyId="Subject"/>
      <taxonomy:taxonomyPropertyField itemId="locTaxonomyItemId"
                                      propertyName="locationTaxonomy"
                                      taxonomyId="Location"/>

As mentioned in the previous section, it is possible to overwrite the existing location or subject taxonomy with a site-depending variant. In this case, it is not necessary to change the configuration for the property field. The taxonomy property editor will always try to identify the site-depending taxonomy with the same name first. If this one is not found, the global taxonomy with the given id will be looked up and used instead. For custom site-specific taxonomy trees, the attribute value taxonomyId must match the name of the newly created taxonomy folder.

How to configure access to the taxonomy content / taxonomy administration

To ensure that the taxonomies are working properly, ensure that the user has the corresponding read and write rights to the settings and taxonomy folders. For taxonomy folders, ensure that also the Folder rights are set.

How to configure contexts for taxonomy trees

Since global taxonomies are not part of the "regular" content hierarchy, they do not have a context. That's why the IsPartOfNavigationValidator of CoreMedia Studio excludes global settings paths, as well as the underlying taxonomy folders from the context validation. If you, however, created a taxonomy tree where this validator complains about a missing context, make sure that the folder of your taxonomy root folder is excluded from the context validation (please refer to Section 3.4.4, “Navigation Validator Configuration” in Deployment Manual).

Taxonomy Manager Access

You can configure the list of user groups that can access the taxonomy manager in the jangaroo.config.js file of the taxonomy extension. By default, the following groups are allowed to open the manager:

  • global-manager
  • taxonomy-manager
  • developer

This list cannot be customized during runtime. To add or remove access for users, ensure that they are a member of the corresponding groups.

Taxonomy Visibility

To allow a more fine-granular access to taxonomy nodes in the Taxonomy Manager, it is possible to configure roles for different taxonomy trees in the TaxonomySettings settings document. The example below shows how to configure the visibility of a global "Subject" taxonomy tree for the user group taxonomy-admin and for the site specific "Subject" taxonomy (with site id "MY_SIDE_ID") for the user group taxonomy-admin.

<Struct xmlns="http://www.coremedia.com/2008/struct" xmlns:xlink="http://www.w3.org/1999/xlink">
    <StructProperty Name="rules">
      <Struct>
        <StructProperty Name="Subject">
          <Struct>
            <StructProperty Name="global">
              <Struct>
                <StringListProperty Name="groups">
                  <String">taxonomy-admin</String>
                </StringListProperty Name="groups">
              </String>
              </Struct>
            </StructProperty>
            <StructProperty Name="MY_SIDE_ID">
              <Struct>
                <StringListProperty Name="groups">
                  <String">taxonomy-admin</String>
                </StringListProperty Name="groups">
              </String>
              </Struct>
            </StructProperty>
          </Struct>
        </StructProperty>
      </Struct>
    </StructProperty>

Note that this configuration only configures the visibility of the taxonomies inside the Taxonomy Manager. User are still able to see matching contents of the taxonomy in the library if they have the corresponding rights.

How to configure taxonomy localization

By default, the localization for taxonomies is enabled and only supports global taxonomy trees. The logic which language should be used when a tag is translated is implemented in the class TaxonomyLocalizationStrategyImpl which implements the interface TaxonomyLocalizationStrategy. The class is located in the content-services modules of the shared/middle workspace. Note that this class is responsible for the localization of taxonomies in all apps: Studio, Headless Server and CAE.

The TaxonomyLocalizationStrategy reads configuration values from global content item /Settings/Options/Settings/TaxonomySettings. The configuration TaxonomySettings contains the StringListProperty translations that contains the list of target locales. The additional defaultLanguage StringProperty defines the locale of the value property of taxonomy content items. This property contains the name of the tag. In a localized context, this name is used when the request language is not available.

<Struct xmlns="http://www.coremedia.com/2008/struct" xmlns:xlink="http://www.w3.org/1999/xlink">
  <StringListProperty Name="translations">
    <String>en</String>
    <String>de</String>
    <String>ja</String>
  </StringListProperty>
  <StringProperty Name="defaultLocale">en<StringProperty>
</Struct>

If the localization shouldn't be used, the field defaultLanguage can be left empty. This will hide the list of localized input fields from the document form. Otherwise, additional StringProperty input fields will be shown for every locale of the translations list. The values are stored in the localSettings of each taxonomy content item.

Taxonomy Localization Form

Figure 5.8. Taxonomy Localization Form


Search Results

Table Of Contents
warning

Your Internet Explorer is no longer supported.

Please use Mozilla Firefox, Google Chrome, or Microsoft Edge.