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

gov.nasa.pds.citool.util.ReferenceUtils Maven / Gradle / Ivy

Go to download

The Catalog Tool provides functionality for ingesting PDS3 catalog files into the the PDS4 infrastructure including the Registry and Storage Services.

There is a newer version: 2.2.0
Show newest version
// Copyright 2009, by the California Institute of Technology.
// ALL RIGHTS RESERVED. United States Government sponsorship acknowledged.
// Any commercial use must be negotiated with the Office of Technology Transfer
// at the California Institute of Technology.
//
// This software is subject to U. S. export control laws and regulations
// (22 C.F.R. 120-130 and 15 C.F.R. 730-774). To the extent that the software
// is subject to U.S. export control laws and regulations, the recipient has
// the responsibility to obtain export licenses or other export authority as
// may be required before exporting such information to foreign countries or
// providing access to foreign nationals.
//
// $Id$
package gov.nasa.pds.citool.util;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.logging.Logger;

import gov.nasa.pds.citool.CIToolIngester;
import gov.nasa.pds.citool.ingestor.CatalogObject;
import gov.nasa.pds.citool.ingestor.CatalogVolumeIngester;
import gov.nasa.pds.citool.ingestor.Constants;
import gov.nasa.pds.citool.registry.model.Metadata;
import gov.nasa.pds.tools.label.AttributeStatement;

public class ReferenceUtils
{
	private static Logger log = Logger.getLogger(ReferenceUtils.class.getName());
	
	private static void handleMissionRefs(Map> refs, CatalogObject catObj)
	{
		Map pdsLbl = catObj.getPdsLabelMap();
		Metadata md = catObj.getMetadata();
		
		String lidValue = null;
		List values = null;
		
		lidValue = pdsLbl.get("MISSION_NAME").getValue().toString();
		lidValue = Utility.collapse(lidValue);
		lidValue = Utility.replaceChars(lidValue);
		lidValue = lidValue.toLowerCase();
		
		if (refs.get(Constants.HAS_MISSION)!=null) 
		{
			values = refs.get(Constants.HAS_MISSION);
		}
		else 
		{
			values = new ArrayList();
		}
		
		values.add(Constants.LID_PREFIX+"investigation:mission."+lidValue);
		refs.put(Constants.HAS_MISSION, values);

		String key = "INSTRUMENT_HOST_ID";
		if (refs.get(Constants.HAS_INSTHOST)!=null) 
		{
			values = refs.get(Constants.HAS_INSTHOST);
		}
		else 
		{
			values = new ArrayList();
		}
		
		if (md.containsKey(key)) 
		{
			if (md.isMultiValued(key)) 
			{
				List tmpValues = md.getAllMetadata(key);
				for (String aVal: tmpValues) {
					lidValue = aVal;
					String instHostType = md.getMetadata("INSTRUMENT_HOST_TYPE");
	    			if (instHostType!=null)
	    				lidValue = instHostType + "." + lidValue; 
	    			else 
	    				lidValue = "instrument_host." + lidValue; 						
					lidValue = Utility.collapse(lidValue);
					lidValue = Utility.replaceChars(lidValue);
					lidValue = lidValue.toLowerCase();
					if (!Utility.valueExists(Constants.LID_PREFIX+"instrument_host:"+lidValue, values))
						values.add(Constants.LID_PREFIX+"instrument_host:"+lidValue);
				}
			}
			else 
			{
				lidValue = md.getMetadata(key);
				String instHostType = md.getMetadata("INSTRUMENT_HOST_TYPE");
    			if (instHostType!=null)
    				lidValue = instHostType + "." + lidValue; 
    			else 
    				lidValue = "instrument_host." + lidValue; 
				lidValue = Utility.collapse(lidValue);
				lidValue = Utility.replaceChars(lidValue);
				lidValue = lidValue.toLowerCase();
				if (!Utility.valueExists(Constants.LID_PREFIX+"instrument_host:"+lidValue, values))
					values.add(Constants.LID_PREFIX+"instrument_host:"+lidValue);          
			}
			
			refs.put(Constants.HAS_INSTHOST, values);
		}
	}

	
	private static void handleDataSetRefs(Map> refs, CatalogObject catObj)
	{
		Map pdsLbl = catObj.getPdsLabelMap();
		Metadata md = catObj.getMetadata();
		
		String lidValue = null;
		List values = null;
		
		lidValue = pdsLbl.get("DATA_SET_ID").getValue().toString();
		lidValue = Utility.collapse(lidValue);
		lidValue = Utility.replaceChars(lidValue);   			
		lidValue = lidValue.toLowerCase();
		
		if (refs.get(Constants.HAS_DATASET)!=null) {
			values = refs.get(Constants.HAS_DATASET);
		}
		else {
			values = new ArrayList();
		}
		
		if (!Utility.valueExists(Constants.LID_PREFIX+"data_set:data_set."+lidValue, values)) {
			values.add(Constants.LID_PREFIX+"data_set:data_set."+lidValue);
		}
		
		refs.put(Constants.HAS_DATASET, values);
		
		String key = "CURATING_NODE_ID";
		if (md.containsKey(key)) {
			if (refs.get(Constants.HAS_NODE)!=null) {
				values = refs.get(Constants.HAS_NODE);
			}
			else {
				values = new ArrayList();
			}
			if (md.isMultiValued(key)) {
				List tmpValues = md.getAllMetadata(key);
				for (String aVal: tmpValues) {
					lidValue = aVal;
					lidValue = Utility.collapse(lidValue);
					lidValue = lidValue.toLowerCase();
					if (!Utility.valueExists(Constants.LID_PREFIX+"node:node."+lidValue, values))
						values.add(Constants.LID_PREFIX+"node:node."+lidValue);
				}
			}
			else {
				lidValue = md.getMetadata(key);
				lidValue = Utility.collapse(lidValue);
				lidValue = lidValue.toLowerCase();
				if (!Utility.valueExists(Constants.LID_PREFIX+"node:node."+lidValue, values))
					values.add(Constants.LID_PREFIX+"node:node."+lidValue);              
			}
			refs.put(Constants.HAS_NODE, values);      
		}
		
		key = "INSTRUMENT_HOST_ID";
		if (refs.get(Constants.HAS_INSTHOST)!=null) {
			values = refs.get(Constants.HAS_INSTHOST);
		}
		else {
			values = new ArrayList();
		}
		if (md.containsKey(key)) {
			if (md.isMultiValued(key)) {
				List tmpValues = md.getAllMetadata(key);
				// remove duplicate value from the tmpValues list
				tmpValues = new ArrayList(new HashSet(tmpValues));
				for (String aVal: tmpValues) {
					lidValue = aVal;
					String instHostType = md.getMetadata("INSTRUMENT_HOST_TYPE");
	    			if (instHostType!=null)
	    				lidValue = instHostType + "." + lidValue; 
	    			else 
	    				lidValue = "instrument_host." + lidValue; 
					lidValue = Utility.collapse(lidValue);
					lidValue = Utility.replaceChars(lidValue);
					lidValue = lidValue.toLowerCase();
					if (!Utility.valueExists(Constants.LID_PREFIX+"instrument_host:"+lidValue, values))
						values.add(Constants.LID_PREFIX+"instrument_host:"+lidValue);
				}
			}
			else {
				lidValue = md.getMetadata(key);
				String instHostType = md.getMetadata("INSTRUMENT_HOST_TYPE");
    			if (instHostType!=null)
    				lidValue = instHostType + "." + lidValue; 
    			else 
    				lidValue = "instrument_host." + lidValue; 
				lidValue = Utility.collapse(lidValue);
				lidValue = Utility.replaceChars(lidValue);
				lidValue = lidValue.toLowerCase();
				if (!Utility.valueExists(Constants.LID_PREFIX+"instrument_host:"+lidValue, values))
					values.add(Constants.LID_PREFIX+"instrument_host:"+lidValue);
			}
			refs.put(Constants.HAS_INSTHOST, values);  				
		}   			

	}
	
	
	private static void handleInstrumentRefs(Map> refs, CatalogObject catObj)
	{
		Map pdsLbl = catObj.getPdsLabelMap();
		
		String lidValue = null;
		List values = null;

		lidValue = pdsLbl.get("INSTRUMENT_ID").getValue().toString();
		String hostId = pdsLbl.get("INSTRUMENT_HOST_ID").getValue().toString();

		if (refs.get(Constants.HAS_INST) != null) 
		{
			values = refs.get(Constants.HAS_INST);
		}
		else 
		{
			values = new ArrayList();
		}
		
		lidValue += "." + hostId;
		lidValue = Utility.collapse(lidValue);
		lidValue = Utility.replaceChars(lidValue);
		lidValue = lidValue.toLowerCase();
		values.add(Constants.LID_PREFIX+"instrument:instrument."+lidValue);

		refs.put(Constants.HAS_INST, values);
	}

	
	private static void handleInstrumentHostRefs(Map> refs, CatalogObject catObj)
	{
		Map pdsLbl = catObj.getPdsLabelMap();
		
		String lidValue = null;
		List values = null;
		
		lidValue = pdsLbl.get("INSTRUMENT_HOST_ID").getValue().toString();
		String instHostType = pdsLbl.get("INSTRUMENT_HOST_TYPE").getValue().toString();
		
		if(instHostType!=null)
			lidValue = instHostType + "." + lidValue; 
		else 
			lidValue = "instrument_host." + lidValue;
		
		lidValue = Utility.collapse(lidValue);
		lidValue = Utility.replaceChars(lidValue);
		lidValue = lidValue.toLowerCase();
		
		if (refs.get(Constants.HAS_INSTHOST)!=null) {
			values = refs.get(Constants.HAS_INSTHOST);
		}
		else {
			values = new ArrayList();
		}
		
		if (!Utility.valueExists(Constants.LID_PREFIX+"instrument_host:"+lidValue, values))
			values.add(Constants.LID_PREFIX+"instrument_host:"+lidValue);

		refs.put(Constants.HAS_INSTHOST, values);
	}
	
	
	private static void handleTargetRefs(Map> refs, CatalogObject catObj, 
			List catObjs)
	{
		Map pdsLbl = catObj.getPdsLabelMap();
		
		String lidValue = null;
		List values = null;
				
		lidValue = pdsLbl.get("TARGET_NAME").getValue().toString();
		String targetType = getTargetType(lidValue, catObjs);
		lidValue = targetType + "." + lidValue;
		lidValue = Utility.collapse(lidValue);
		lidValue = Utility.replaceChars(lidValue);
		lidValue = lidValue.toLowerCase();
		if (refs.get(Constants.HAS_TARGET)!=null) 
		{
			values = refs.get(Constants.HAS_TARGET);
		}
		else 
		{
			values = new ArrayList();
		}
		 			
		if (!Utility.valueExists(Constants.LID_PREFIX+"target:" + lidValue, values)) 
		{
			values.add(Constants.LID_PREFIX+"target:" + lidValue);
		}
		
		refs.put(Constants.HAS_TARGET, values);		
	}

	
	private static void handleResourceRefs(Map> refs, CatalogObject catObj)
	{
		Map pdsLbl = catObj.getPdsLabelMap();
		Metadata md = catObj.getMetadata();
		
		String lidValue = null;
		List values = null;
		
		if (refs.get(Constants.HAS_RESOURCE)!=null) 
		{
			values = refs.get(Constants.HAS_RESOURCE);
		}
		else 
		{
			values = new ArrayList();
		}
		
		String dsId = pdsLbl.get("DATA_SET_ID").getValue().toString();   
		String key = "RESOURCE_ID";
		if (md.containsKey(key)) {
			if (md.isMultiValued(key)) {
				List tmpValues = md.getAllMetadata(key);    				
				for (String aVal: tmpValues) {				
					lidValue = dsId + "__" + aVal; 
					lidValue = Utility.collapse(lidValue);
					lidValue = Utility.replaceChars(lidValue);
					lidValue = lidValue.toLowerCase();
					if (!Utility.valueExists(Constants.LID_PREFIX+"resource:resource."+lidValue, values))
						values.add(Constants.LID_PREFIX+"resource:resource."+lidValue);
				}
			}
			else {
				lidValue = md.getMetadata(key);
				lidValue = dsId + "__" + lidValue;
				lidValue = Utility.collapse(lidValue);
				lidValue = Utility.replaceChars(lidValue);
				lidValue = lidValue.toLowerCase();
				if (!Utility.valueExists(Constants.LID_PREFIX+"resource:resource."+lidValue, values))
					values.add(Constants.LID_PREFIX+"resource:resource."+lidValue);
			}
			refs.put(Constants.HAS_RESOURCE, values);   
		}
		
		key = "CURATING_NODE_ID";
		if (md.containsKey(key)) {
			if (refs.get(Constants.HAS_NODE) != null) {
				values = refs.get(Constants.HAS_NODE);
			} else {
				values = new ArrayList();
			}
			if (md.isMultiValued(key)) {
				List tmpValues = md.getAllMetadata(key);
				for (String aVal : tmpValues) {
					lidValue = aVal;
					lidValue = Utility.collapse(lidValue);
					lidValue = lidValue.toLowerCase();
					if (!Utility.valueExists(Constants.LID_PREFIX + "node:node." + lidValue, values))
						values.add(Constants.LID_PREFIX + "node:node." + lidValue);
				}
			} else {
				lidValue = md.getMetadata(key);
				lidValue = Utility.collapse(lidValue);
				lidValue = lidValue.toLowerCase();
				if (!Utility.valueExists(Constants.LID_PREFIX + "node:node." + lidValue, values))
					values.add(Constants.LID_PREFIX + "node:node." + lidValue);
			}
			refs.put(Constants.HAS_NODE, values);  
		}
	}

	
	private static void handleVolumeRefs(Map> refs, CatalogObject catObj)
	{
		Map pdsLbl = catObj.getPdsLabelMap();
		Metadata md = catObj.getMetadata();
		
		String lidValue = null;
		List values = null;
	
		lidValue = pdsLbl.get("VOLUME_ID").getValue().toString();
		//ingester.setStorageProductName(lidValue);
		
		String key = "DATA_SET_ID";  
		key = Utility.replaceChars(key);
		if (refs.get(Constants.HAS_DATASET)!=null)
			values = refs.get(Constants.HAS_DATASET);
		else
			values = new ArrayList();
		
		// PDS-278 issue
		String dsCollKey = "DATA_SET_COLL_OR_DATA_SET_ID";
		if (md.containsKey(key)) {
			if (md.containsKey(dsCollKey)) {
				System.err.println("\nBoth DATA_SET_ID and DATA_SET_COLL_OR_DATA_SET_ID are present in a volume descriptor catalog file. " +
						"Remove one of them and rerun the Catalog Tool.\n");
				System.exit(1);
			}	
		}
		else {
			if (md.containsKey(dsCollKey)) {
				key = dsCollKey;
			}
			else {
				System.err.println("\nNeither DATA_SET_ID nor DATA_SET_COLL_OR_DATA_SET_ID are present in a volume descriptor catalog file. " +
						"Make sure to include one of them in a volume descriptor catalog file.\n");
				System.exit(1);
			}
		}
		
		// DATA_SET_ID or DATA_SET_COLL_OR_DATA_SET_ID, if both appears, throw an exception, don't ingest...
		// if one of them appear, use it.
		if (md.isMultiValued(key)) {
			List tmpValues = md.getAllMetadata(key);
			for (String aVal: tmpValues) {
				lidValue = aVal;
				lidValue = Utility.collapse(lidValue);
				lidValue = Utility.replaceChars(lidValue);
				lidValue = lidValue.toLowerCase();
				// shouldn't add if the value is already exists in the list
				if (!Utility.valueExists(Constants.LID_PREFIX+"data_set:data_set."+lidValue, values)) {
					values.add(Constants.LID_PREFIX+"data_set:data_set."+lidValue);
				}
			}
		}
		else {
			lidValue = md.getMetadata(key);
			lidValue = Utility.collapse(lidValue);
			lidValue = Utility.replaceChars(lidValue);
			lidValue = lidValue.toLowerCase();
			if (!Utility.valueExists(Constants.LID_PREFIX+"data_set:data_set."+lidValue, values)) {
				values.add(Constants.LID_PREFIX+"data_set:data_set."+lidValue);         
			}
		} 

		refs.put(Constants.HAS_DATASET, values);
	}
	
	
    /**
     * Generates reference class object for association information
     */
    public static Map> populateReferenceEntries(CatalogVolumeIngester catIngester)
    {
    	Map> refs = new HashMap>();
    	
    	for (CatalogObject tmpCatObj: catIngester.getCatalogObjects()) 
    	{
    		String catObjType = tmpCatObj.getCatObjType();
    	
    		if(catObjType.equalsIgnoreCase(Constants.MISSION_OBJ)) 
    		{
    			handleMissionRefs(refs, tmpCatObj);
    		}
    		else if (catObjType.equalsIgnoreCase(Constants.DATASET_OBJ)) 
    		{
    			handleDataSetRefs(refs, tmpCatObj);
    		}
    		else if (catObjType.equalsIgnoreCase(Constants.INST_OBJ)) 
    		{
    			handleInstrumentRefs(refs, tmpCatObj);
    		}
    		else if (catObjType.equalsIgnoreCase(Constants.INSTHOST_OBJ)) 
    		{
    			handleInstrumentHostRefs(refs, tmpCatObj);
    		}
    		else if (catObjType.equalsIgnoreCase(Constants.TARGET_OBJ)) 
    		{
    			catIngester.setTargetAvailable(true);
    			handleTargetRefs(refs, tmpCatObj, catIngester.getCatalogObjects());
    		}
    		else if (catObjType.equalsIgnoreCase(Constants.RESOURCE_OBJ) || 
    				 catObjType.equalsIgnoreCase(Constants.HK_OBJ)) 
    		{	
    			handleResourceRefs(refs, tmpCatObj);
    		}
    		else if (catObjType.equalsIgnoreCase(Constants.VOLUME_OBJ)) 
    		{
    			handleVolumeRefs(refs, tmpCatObj);
    		}
    	}
    	
    	return refs;
    }

    
    private static String getTargetType(String targetName, List catObjs)
    {
    	Map targetInfos = getTargetInfos(targetName, catObjs);
    	String targetType = "target";
    	
    	if(targetInfos != null) 
    	{
			targetType = targetInfos.get(targetName);
			if(targetType == null) 
			{
				targetType = "target";
			}
			else 
			{
				if (targetType.equalsIgnoreCase("n/a"))
					targetType = "unk";
				if (targetType.toLowerCase().startsWith("unk")) 
					targetType = "unk";
			}
    	}

    	return targetType;
    }


    public static Map getTargetInfos(String targetName, List catObjs) 
    {
    	for (CatalogObject catObj: catObjs) 
    	{
    		if (catObj.getCatObjType().equalsIgnoreCase(Constants.TARGET_OBJ)) 
    		{
    			if (catObj.getMetadata().getMetadata("TARGET_NAME").equalsIgnoreCase(targetName)) 
    			{  				
    				return catObj.getTargetInfos();
    			}
    		}
    	}
    	
    	return null;
    }

    
    // only retrieve the list from the same catalog object
	public static List getRefValues(String version, String associationType, 
			Map> allRefs, CatalogObject catObj) 
	{	
		List values = new ArrayList();
	
		if (associationType==Constants.HAS_MISSION) 
		{
			return getRefs("MISSION_NAME", associationType, allRefs, catObj);
		}
		else if (associationType==Constants.HAS_INSTHOST) 
		{
			return getRefs("INSTRUMENT_HOST_ID", associationType, allRefs, catObj);
		}
		else if (associationType==Constants.HAS_INST) 
		{
			return getRefs("INSTRUMENT_ID", associationType, allRefs, catObj);
		}
		else if (associationType==Constants.HAS_TARGET) 
		{
			return getRefs("TARGET_NAME", associationType, allRefs, catObj);
		}
		else if (associationType==Constants.HAS_DATASET) 
		{
			return getRefs("DATA_SET_ID", associationType, allRefs, catObj);
		}
		
		return values;
	}

	
	private static List getRefs(String key, String associationType, Map> allRefs, CatalogObject catObj) 
	{
		List values = new ArrayList();
		Metadata md = catObj.getMetadata();
		
		if (md.isMultiValued(key)) 
		{
			List tmpValues = md.getAllMetadata(key);			
			// remove duplicate value from the tmpValues list
			tmpValues = new ArrayList(new HashSet(tmpValues));
				
			for (String valueToMatch: tmpValues) 
			{
				valueToMatch = Utility.collapse(valueToMatch);
				valueToMatch = Utility.replaceChars(valueToMatch);
				values.addAll(getRefsList(key, valueToMatch, allRefs, associationType, catObj));
			}
		} 
		else 
		{
			String valueToMatch = md.getMetadata(key);
			
			if(valueToMatch == null)
			{
				log.warning(catObj.getCatObjType() + ": "+ key + " = NULL");
			}
			else
			{
				valueToMatch = Utility.collapse(valueToMatch);
				valueToMatch = Utility.replaceChars(valueToMatch);
				values = getRefsList(key, valueToMatch, allRefs, associationType, catObj);
			}			
		}
		
		return values;
	}
	
	private static List getRefsList(String key, String valueToMatch, Map> allRefs, 
			String associationType, CatalogObject catObj) 
	{
		List values = new ArrayList();
		String valueToCompare = "";
		for (String aValue: allRefs.get(associationType)) 
		{		
			if (key.equalsIgnoreCase("TARGET_NAME")) 
			{
				valueToCompare = aValue.substring(aValue.lastIndexOf(".") + 1);
				
				if (valueToCompare.equalsIgnoreCase(valueToMatch.toLowerCase())) 
				{
					if (!Utility.valueExists(aValue, values)) {
						values.add(aValue); 
					}
				}						
			}
			else 
			{				
				boolean okToAdd = false;
				if (associationType.equalsIgnoreCase("instrument_host_ref"))
					okToAdd = aValue.endsWith(valueToMatch.toLowerCase());
				else 
					okToAdd = aValue.contains(valueToMatch.toLowerCase());
				
				if (okToAdd)
				{
					values.add(aValue);
				}
			}
		}
		
		return values;
	}

	
	public static List getRefValues(String version, String associationType,  Map> allRefs) 
	{	
		List values = new ArrayList();
	
		for (String aValue: allRefs.get(associationType)) 
		{
			if (!Utility.valueExists(aValue, values)) 
			{
				values.add(aValue);
			}
		}
		
		return values;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy