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

thredds.client.catalog.Dataset Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 1998-2018 University Corporation for Atmospheric Research/Unidata
 * See LICENSE for license information.
 */
package thredds.client.catalog;

import com.google.common.collect.ImmutableSet;
import thredds.client.catalog.builder.AccessBuilder;
import thredds.client.catalog.builder.DatasetBuilder;
import ucar.nc2.units.DateRange;
import ucar.nc2.units.DateType;
import javax.annotation.concurrent.Immutable;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Map;

/**
 * A Client Catalog Dataset
 * 
 * @author caron
 * @since 1/7/2015
 */
@Immutable
public class Dataset extends DatasetNode implements ThreddsMetadataContainer {
  public static final String Access = "Access"; // Access or list of Access
  public static final String Alias = "Alias"; // String
  public static final String Authority = "Authority"; // String
  public static final String CollectionType = "CollectionType"; // String
  public static final String Contributors = "Contributors"; // Contributor or List of Contributor
  public static final String Creators = "Creators"; // String or List of String
  public static final String DataFormatType = "DataFormatType"; // String
  public static final String Datasets = "Datasets"; // unmodifiable List
  public static final String DataSize = "DataSize"; // Long
  public static final String Dates = "Dates"; // DateType or List of DateType
  public static final String Documentation = "Documentation"; // Documentation or List of Documentation
  public static final String FeatureType = "FeatureType"; // String
  public static final String GeospatialCoverage = "GeospatialCoverage"; // ThreddsMetadata.GeospatialCoverage
  public static final String Harvest = "Harvest"; // Boolean
  public static final String Id = "Id"; // String
  public static final String Keywords = "Keywords"; // Vocab or List of Vocab
  public static final String MetadataOther = "MetadataOther"; // MetadataOther or List of MetadataOther
  public static final String Ncml = "Ncml"; // jdom2.Element
  public static final String Projects = "Projects"; // Vocab or List of Vocab
  public static final String Properties = "Properties"; // Property or List of Property
  public static final String Publishers = "Publishers"; // Source or List of Source
  public static final String RestrictAccess = "RestrictAccess"; // String
  public static final String ServiceName = "ServiceName"; // String
  public static final String ThreddsMetadataInheritable = "ThreddsMetadataInheritable"; // ThreddsMetadata
  public static final String TimeCoverage = "TimeCoverage"; // DateRange
  public static final String VariableGroups = "VariableGroups"; // VariableGroup or List of VariableGroup
  public static final String VariableMapLinkURI = "VariableMapLinkURI"; // ThreddsMetadata.UriResolved
  public static final String UrlPath = "UrlPath"; // String
  public static final String UseRemoteCatalogService = "UseRemoteCatalogService"; // Boolean

  public static final String NotAThreddsDataset = "NotAThreddsDataset"; // used to set Property in catalog

  public static final ImmutableSet listFlds = ImmutableSet.of(Access, Contributors, Creators, Dates,
      Documentation, Keywords, MetadataOther, Projects, Properties, Publishers, VariableGroups);

  ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

  public Dataset(DatasetNode parent, String name, Map flds, List accessBuilders,
      List datasetBuilders) {
    super(parent, name, flds, datasetBuilders);

    if (accessBuilders != null && !accessBuilders.isEmpty()) {
      List access = new ArrayList<>(accessBuilders.size());
      for (AccessBuilder acc : accessBuilders)
        access.add(acc.makeAccess(this));
      flds.put(Access, Collections.unmodifiableList(access));
    }
  }

  /**
   * Construct an Dataset which refers to a urlPath.
   * This is used to create a standalone Dataset, outside of an Catalog.
   * An "anonymous" Service is created and attached to the Dataset.
   *
   * @param urlPath : construct URL from this path
   * @param featureType : feature type
   * @param dataFormatS : data format
   * @param serviceType : ServiceType
   */
  public static Dataset makeStandalone(String urlPath, String featureType, String dataFormatS, String serviceType) {
    DatasetBuilder builder = new DatasetBuilder(null);
    builder.put(FeatureType, featureType);
    Service service = new Service("anon", "", serviceType, null, null, null, null, null);
    AccessBuilder access = new AccessBuilder(builder, urlPath, service, dataFormatS, 0);
    builder.addAccess(access);
    return builder.makeDataset(null);
  }

  /////////////////////////////////////////////////////

  public List getAccess() {
    List result = new ArrayList<>();
    String urlPath = getUrlPath();
    String serviceDefault = getServiceNameDefault();
    String dataFormat = getDataFormatName();
    long dataSize = getDataSize();

    Catalog cat = getParentCatalog();
    if (cat != null) {
      Service s = cat.findService(serviceDefault);

      // add access element if urlPath and service is specified
      if ((urlPath != null) && (s != null)) {
        Access a = new Access(this, urlPath, s, dataFormat, dataSize);
        addAllAccess(a, result);
      }
    }

    // add local access elements
    List access = (List) getLocalFieldAsList(Access);
    if (access != null) {
      for (Access a : access) {
        addAllAccess(a, result);
      }
    }

    return result;
  }

  private void addAllAccess(Access a, List result) {
    Service service = a.getService();
    if (service != null) {
      if (a.getService().getType() == ServiceType.Compound) {
        for (Service nested : a.getService().getNestedServices()) {
          Access nestedAccess = new Access(this, a.getUrlPath(), nested, a.getDataFormatName(), a.getDataSize());
          addAllAccess(nestedAccess, result); // i guess it could recurse
        }
      } else {
        result.add(a);
      }
    }
  }

  public Access getAccess(ServiceType type) {
    for (Access acc : getAccess())
      if (acc.getService().getType() == type)
        return acc;
    return null;
  }

  public boolean hasAccess() {
    List access = getAccess();
    return !access.isEmpty();
  }

  /**
   * Get access element that matches the given access standard URL.
   * Match on a.getStandardUrlName().
   *
   * @param accessURL find theis access URL string
   * @return InvAccess or null if no match.
   */
  public Access findAccess(String accessURL) {
    for (Access a : getAccess()) {
      if (accessURL.equals(a.getStandardUrlName()))
        return a;
    }
    return null;
  }

  /**
   * Get URL to this dataset. Dataset must have an ID.
   * Form is catalogURL#DatasetID
   *
   * @return URL to this dataset.
   */
  public String getCatalogUrl() {
    Catalog parent = getParentCatalog();
    if (parent == null)
      return null;
    String baseUri = parent.getUriString();
    if (baseUri == null)
      return null;
    return baseUri + "#" + getId();
  }

  /////////////////////////////////////////////////////
  // non-inheritable metadata
  public String getCollectionType() {
    return (String) flds.get(CollectionType);
  }

  public boolean isDatasetScan() {
    return false;
  }

  public boolean isHarvest() {
    Boolean result = (Boolean) flds.get(Harvest);
    return (result != null) && result;
  }

  public String getId() {
    return (String) flds.get(Id);
  }

  public String getID() {
    return getId();
  }

  public String getUrlPath() {
    return (String) flds.get(UrlPath);
  }

  public String getIdOrPath() {
    String id = getId();
    return (id != null) ? id : getUrlPath();
  }

  public org.jdom2.Element getNcmlElement() {
    return (org.jdom2.Element) getLocalField(Dataset.Ncml);
  }

  /////////////////////////////////////////////////////
  // inheritable metadata

  @Override
  public Object getLocalField(String fldName) {
    return flds.get(fldName);
  }

  Object getInheritedOnlyField(String fldName) {
    ThreddsMetadata tmi = (ThreddsMetadata) flds.get(ThreddsMetadataInheritable);
    if (tmi != null) {
      Object value = tmi.getLocalField(fldName);
      if (value != null)
        return value;
    }
    Dataset parent = getParentDataset();
    return (parent == null) ? null : parent.getInheritedOnlyField(fldName);
  }

  Object getInheritedField(String fldName) {
    Object value = flds.get(fldName);
    if (value != null)
      return value;
    return getInheritedOnlyField(fldName);
  }

  public String getAuthority() {
    return (String) getInheritedField(Authority);
  }

  public String getDataFormatName() {
    return (String) getInheritedField(DataFormatType);
  }

  public ucar.nc2.constants.DataFormatType getDataFormatType() {
    String name = getDataFormatName();
    if (name == null)
      return null;
    try {
      return ucar.nc2.constants.DataFormatType.getType(name);
    } catch (Exception e) {
      return null;
    }
  }

  public long getDataSize() {
    Long size = (Long) getInheritedField(DataSize);
    return (size == null) ? -1 : size;
  }

  public boolean hasDataSize() {
    Long size = (Long) getInheritedField(DataSize);
    return (size != null) && size > 0;
  }

  public ucar.nc2.constants.FeatureType getFeatureType() {
    String name = getFeatureTypeName();
    try {
      return ucar.nc2.constants.FeatureType.getType(name);
    } catch (Exception e) {
      return null;
    }
  }

  public String getFeatureTypeName() {
    return (String) getInheritedField(FeatureType);
  }

  public ThreddsMetadata.GeospatialCoverage getGeospatialCoverage() {
    return (ThreddsMetadata.GeospatialCoverage) getInheritedField(GeospatialCoverage);
  }

  public String getServiceNameDefault() {
    return (String) getInheritedField(ServiceName);
  }

  public Service getServiceDefault() {
    Catalog cat = getParentCatalog();
    if (cat == null)
      return null;
    return cat.findService(getServiceNameDefault());
  }

  public String getRestrictAccess() {
    return (String) getInheritedField(RestrictAccess);
  }

  public DateRange getTimeCoverage() {
    return (DateRange) getInheritedField(TimeCoverage);
  }

  public ThreddsMetadata.UriResolved getVariableMapLink() {
    return (ThreddsMetadata.UriResolved) getInheritedField(VariableMapLinkURI);
  }

  ///////////////////////////////////////////

  List getInheritedFieldAsList(String fldName) {
    List result = new ArrayList();
    Object value = flds.get(fldName); // first look for local
    if (value != null) {
      if (value instanceof List)
        result.addAll((List) value);
      else
        result.add(value);
    }

    getAllFromInherited(fldName, result); // then look for inherited
    return result;
  }

  void getAllFromInherited(String fldName, List result) {
    ThreddsMetadata tmi = (ThreddsMetadata) flds.get(ThreddsMetadataInheritable);
    if (tmi != null) {
      Object value = tmi.getLocalField(fldName);
      if (value != null) {
        if (value instanceof List)
          result.addAll((List) value);
        else
          result.add(value);
      }
    }
    Dataset parent = getParentDataset();
    if (parent != null)
      parent.getAllFromInherited(fldName, result);
  }


  public List getCreators() {
    return (List) getInheritedFieldAsList(Dataset.Creators);
  }

  public List getContributors() {
    return (List) getInheritedFieldAsList(Dataset.Contributors);
  }

  public List getDates() {
    return (List) getInheritedFieldAsList(Dates);
  } // prob only one type

  public List getDocumentation() {
    return (List) getInheritedFieldAsList(Documentation);
  }

  public List getKeywords() {
    return (List) getInheritedFieldAsList(Keywords);
  }

  public List getMetadataOther() {
    return (List) getInheritedFieldAsList(MetadataOther);
  }

  public java.util.List getMetadata(String want) {
    List result = new ArrayList<>();
    for (ThreddsMetadata.MetadataOther m : getMetadataOther()) {
      if (m.getType() != null && m.getType().equalsIgnoreCase(want))
        result.add(m);
    }
    return result;
  }

  public List getProjects() {
    return (List) getInheritedFieldAsList(Projects);
  }

  public List getProperties() {
    List result = getInheritedFieldAsList(Properties);
    return Property.removeDups(result);
  }

  // find the first property with that name
  public String findProperty(String name) {
    Property result = null;
    for (Property p : getProperties()) {
      if (p.getName().equals(name))
        result = p;
    }
    return (result == null) ? null : result.getValue();
  }

  public boolean hasProperty(Property want) {
    return getProperties().contains(want);
  }

  public boolean hasProperty(String name) {
    return findProperty(name) != null;
  }

  public List getPublishers() {
    return (List) getInheritedFieldAsList(Dataset.Publishers);
  }

  public List getVariables() {
    return (List) getInheritedFieldAsList(Dataset.VariableGroups);
  }

  public String getDocumentation(String type) {
    for (Documentation doc : getDocumentation()) {
      String dtype = doc.getType();
      if ((dtype != null) && dtype.equalsIgnoreCase(type))
        return doc.getInlineContent();
    }
    return null;
  }

  /**
   * @return specific type of documentation = history
   */
  public String getHistory() {
    return getDocumentation("history");
  }

  /**
   * @return specific type of documentation = processing_level
   */
  public String getProcessing() {
    return getDocumentation("processing_level");
  }

  /**
   * @return specific type of documentation = rights
   */
  public String getRights() {
    return getDocumentation("rights");
  }

  /**
   * @return specific type of documentation = summary
   */
  public String getSummary() {
    return getDocumentation("summary");
  }

  public DateType getLastModifiedDate() {
    for (DateType dateType : getDates()) {
      if ((dateType.getType() != null) && dateType.getType().equals("modified")) {
        return dateType;
      }
    }
    return null;
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy