/*
* #%L
* wcm.io
* %%
* Copyright (C) 2014 wcm.io
* %%
* 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.
* #L%
*/
package io.wcm.wcm.commons.util;
import java.util.EnumSet;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.apache.commons.lang3.StringUtils;
import org.osgi.annotation.versioning.ProviderType;
import com.day.cq.wcm.api.NameConstants;
import com.day.cq.wcm.api.Page;
/**
* Template utility methods
*/
@ProviderType
public final class Template {
static final Pattern TEMPLATE_PATH_PATTERN = Pattern.compile("^/(apps|libs)/(.+)/templates(/.*)?/([^/]+)$");
private Template() {
// static methods only
}
/**
* Gets the resource type for a given template path.
* This i based on the assumption that:
* Given a template path is /apps/{app_path}/tempaltes/{optinal_path}/{template_path}
* then the resource path is at {app_path}/components/{optinal_path}/page/{template_path}
* @param templatePath Template path
* @return Resource type path or null if template path did not match expectations
*/
public static String getResourceTypeFromTemplatePath(String templatePath) {
if (templatePath == null) {
return null;
}
String resource = null;
Matcher matcher = TEMPLATE_PATH_PATTERN.matcher(templatePath);
if (matcher.matches()) {
resource = matcher.group(2) + "/components"
+ StringUtils.defaultString(matcher.group(3)) + "/page/" + matcher.group(4);
}
return resource;
}
/**
* Checks if the given page uses a specific template.
* @param page AEM page
* @param templates Template(s)
* @return true if the page uses the template
*/
public static boolean is(Page page, TemplatePathInfo... templates) {
if (page == null || templates == null || templates.length == 0) {
return false;
}
String templatePath = page.getProperties().get(NameConstants.PN_TEMPLATE, String.class);
for (TemplatePathInfo template : templates) {
if (template.getTemplatePath().equals(templatePath)) {
return true;
}
}
return false;
}
/**
* Checks if the given page uses a specific template.
* @param page AEM page
* @param templatePaths Template path(s)
* @return true if the page uses the template
*/
public static boolean is(Page page, String... templatePaths) {
if (page == null || templatePaths == null || templatePaths.length == 0) {
return false;
}
String templatePath = page.getProperties().get(NameConstants.PN_TEMPLATE, String.class);
for (String givenTemplatePath : templatePaths) {
if (StringUtils.equals(templatePath, givenTemplatePath)) {
return true;
}
}
return false;
}
/**
* Lookup a template by the given template path.
* @param templatePath Path of template
* @param templates Templates
* @return The {@link TemplatePathInfo} instance or null for unknown template paths
*/
public static TemplatePathInfo forTemplatePath(String templatePath, TemplatePathInfo... templates) {
if (templatePath == null || templates == null || templates.length == 0) {
return null;
}
for (TemplatePathInfo template : templates) {
if (StringUtils.equals(template.getTemplatePath(), templatePath)) {
return template;
}
}
return null;
}
/**
* Lookup a template by the given template path.
* @param templatePath Path of template
* @param templateEnums Templates
* @param <E> Template enum
* @return The {@link TemplatePathInfo} instance or null for unknown template paths
*/
@SafeVarargs
public static <E extends Enum<E> & TemplatePathInfo> TemplatePathInfo forTemplatePath(String templatePath, Class<E>... templateEnums) {
if (templatePath == null || templateEnums == null) {
return null;
}
for (Class<E> templateEnum : templateEnums) {
for (E template : EnumSet.allOf(templateEnum)) {
if (StringUtils.equals(template.getTemplatePath(), templatePath)) {
return template;
}
}
}
return null;
}
/**
* Lookup template for given page.
* @param page Page
* @param templates Templates
* @return The {@link TemplatePathInfo} instance or null for unknown template paths
*/
public static TemplatePathInfo forPage(Page page, TemplatePathInfo... templates) {
if (page == null || templates == null) {
return null;
}
String templatePath = page.getProperties().get(NameConstants.PN_TEMPLATE, String.class);
return forTemplatePath(templatePath, templates);
}
/**
* Lookup template for given page.
* @param page Page
* @param templateEnums Templates
* @param <E> Tempalte enum
* @return The {@link TemplatePathInfo} instance or null for unknown template paths
*/
@SafeVarargs
public static <E extends Enum<E> & TemplatePathInfo> TemplatePathInfo forPage(Page page, Class<E>... templateEnums) {
if (page == null || templateEnums == null) {
return null;
}
String templatePath = page.getProperties().get(NameConstants.PN_TEMPLATE, String.class);
return forTemplatePath(templatePath, templateEnums);
}
}