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

io.kestros.commons.structuredslingmodels.BaseResource Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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 io.kestros.commons.structuredslingmodels;

import static org.apache.jackrabbit.JcrConstants.JCR_CREATED;
import static org.apache.jackrabbit.JcrConstants.JCR_LASTMODIFIED;
import static org.apache.jackrabbit.JcrConstants.JCR_PRIMARYTYPE;
import static org.apache.jackrabbit.vault.util.JcrConstants.JCR_DESCRIPTION;
import static org.apache.jackrabbit.vault.util.JcrConstants.JCR_TITLE;
import static org.apache.sling.api.resource.ResourceResolver.PROPERTY_RESOURCE_TYPE;

import com.fasterxml.jackson.annotation.JsonIgnore;
import io.kestros.commons.structuredslingmodels.annotation.KestrosModel;
import io.kestros.commons.structuredslingmodels.annotation.KestrosProperty;
import io.kestros.commons.structuredslingmodels.exceptions.NoParentResourceException;
import io.kestros.commons.structuredslingmodels.utils.SlingModelUtils;
import java.util.Date;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import org.apache.commons.lang3.StringUtils;
import org.apache.sling.api.resource.Resource;
import org.apache.sling.api.resource.ResourceResolver;
import org.apache.sling.api.resource.ValueMap;
import org.apache.sling.models.annotations.Model;
import org.apache.sling.models.annotations.injectorspecific.Self;

/**
 * Baseline Sling Model to extend all Resource Models from.
 */
@KestrosModel(docPaths = {
    "/content/guide-articles/kestros/structured-models/extending-base-resource",
    "/content/guide-articles/kestros/structured-models/model-validation",
    "/content/guide-articles/kestros/structured-models/using-sling-model-utils",
    "/content/guide-articles/kestros/structured-models/using-common-validators"})
@Model(adaptables = Resource.class,
       resourceType = "sling/servlet/default")
public class BaseResource extends BaseSlingModel {

  /**
   * Original Resource the current Model was adapted from.
   */
  @Self
  private Resource resource;

  /**
   * Original Resource the current Model was adapted from.
   *
   * @return Original Resource the current Model was adapted from.
   */
  @JsonIgnore
  @Nonnull
  public Resource getResource() {
    return resource;
  }

  /**
   * Parent Resource, adapted to BaseResource.
   *
   * @return Parent Resource, adapted to BaseResource.
   * @throws NoParentResourceException No parent was found. Should only happen on the `/`
   *     resource.
   */
  @JsonIgnore
  public BaseResource getParent() throws NoParentResourceException {
    return SlingModelUtils.getParentResourceAsBaseResource(this);
  }

  /**
   * Resource name the current model was adapted from.
   *
   * @return Resource name the current model was adapted from.
   */
  @Nonnull
  @KestrosProperty(description = "Name of the current Resource.")
  public String getName() {
    return resource.getName();
  }

  /**
   * Path to the resource the current model was adapted from.
   *
   * @return Path to the resource the current model was adapted from.
   */
  @Nonnull
  @KestrosProperty(description = "Path to the current Resource.")
  public String getPath() {
    return resource.getPath();
  }

  /**
   * Property ValueMap associated to the resource the current model was adapted from.
   *
   * @return Property ValueMap associated to the resource the current model was adapted from.
   */
  @JsonIgnore
  @Nonnull
  public ValueMap getProperties() {
    return getResource().getValueMap();
  }

  /**
   * Property value, or the default value.
   *
   * @param key Property to retrieve
   * @param defaultValue Value to return if no matching property is found.
   * @param  Generic type.
   * @return Property value, or the default value.
   */
  @Nullable
  public  T getProperty(@Nonnull final String key, final T defaultValue) {
    return getProperties().get(key, defaultValue);
  }

  /**
   * Pull the value from jcr:content, or the Resource name if jcr:title is empty or null.
   *
   * @return Title of the current Resource.
   */
  @Nonnull
  @KestrosProperty(description = "Title of the current resource.",
                   jcrPropertyName = JCR_TITLE,
                   configurable = true)
  public String getTitle() {
    return getProperty(JCR_TITLE, getName());
  }

  /**
   * Description of the current Resource.
   *
   * @return Description of the current Resource.
   */
  @Nonnull
  @KestrosProperty(description = "Description of the current Resource.",
                   jcrPropertyName = JCR_DESCRIPTION,
                   configurable = true)
  public String getDescription() {
    return getProperty(JCR_DESCRIPTION, StringUtils.EMPTY);
  }

  /**
   * Looks to sling:resourceType first, if that is empty, then jcr:primaryType.
   *
   * @return ResourceType of the current Resource.
   */
  @Nonnull
  @KestrosProperty(description = "ResourceType the current resource will be displayed as when "
                                 + "requested.")
  public String getResourceType() {
    if (StringUtils.isNotEmpty(getSlingResourceType())) {
      return getSlingResourceType();
    } else if (StringUtils.isNotEmpty(getResource().getResourceType())) {
      return getResource().getResourceType();
    } else {
      return getJcrPrimaryType();
    }
  }

  /**
   * jcr:primaryType value of the Resource.
   *
   * @return jcr:primaryType value of the Resource.
   */
  @Nonnull
  @JsonIgnore
  public String getJcrPrimaryType() {
    return getProperty(JCR_PRIMARYTYPE, StringUtils.EMPTY);
  }

  /**
   * sling:resourceType property of the current Resource, or an empty String.
   *
   * @return sling:resourceType property of the current Resource, or an empty String.
   */
  @Nonnull
  @JsonIgnore
  public String getSlingResourceType() {
    return getProperty(PROPERTY_RESOURCE_TYPE, StringUtils.EMPTY);
  }

  /**
   * sling:resourceSuperType property of the current Resource.
   *
   * @return SuperType of the current Resource, or an empty String.
   */
  @JsonIgnore
  @Nonnull
  public String getResourceSuperType() {
    final String resourceSuperType = getResource().getResourceSuperType();
    if (StringUtils.isNotEmpty(resourceSuperType)) {
      return resourceSuperType;
    }
    return StringUtils.EMPTY;
  }

  /**
   * ResourceResolver associated to the current Resource.
   *
   * @return ResourceResolver associated to the current Resource.
   */
  @Nonnull
  @JsonIgnore
  public final ResourceResolver getResourceResolver() {
    return getResource().getResourceResolver();
  }

  /**
   * Date when the current Resource was last modified, or null if the property is not found.
   *
   * @return Date when the current Resource was last modified.
   */
  @Nullable
  @JsonIgnore
  public Date getLastModifiedDate() {
    return getProperties().get(JCR_LASTMODIFIED, Date.class);
  }

  /**
   * Date when the current Resource was created, or null if the property is not found.
   *
   * @return Date when the current Resource was created.
   */
  @Nullable
  @JsonIgnore
  public Date getCreatedDate() {
    return getProperties().get(JCR_CREATED, Date.class);
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy