Gianpaolo Coro 2014-02-24 11:53:03 +00:00
parent c8ba7f4280
commit 14ad264370
1 changed files with 519 additions and 0 deletions

View File

@ -0,0 +1,519 @@
package org.gcube.dataanalysis.geo.infrastructure;
import it.geosolutions.geonetwork.util.GNSearchRequest;
import it.geosolutions.geonetwork.util.GNSearchResponse;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.gcube.common.scope.api.ScopeProvider;
import org.gcube.contentmanagement.lexicalmatcher.utils.AnalysisLogger;
import org.gcube.spatial.data.geonetwork.GeoNetwork;
import org.gcube.spatial.data.geonetwork.GeoNetworkReader;
import org.gcube.spatial.data.geonetwork.LoginLevel;
import org.gcube.spatial.data.geonetwork.configuration.Configuration;
import org.gcube.spatial.data.geonetwork.configuration.ConfigurationManager;
import org.geotoolkit.metadata.iso.identification.DefaultDataIdentification;
import org.opengis.metadata.Metadata;
import org.opengis.metadata.citation.OnlineResource;
import org.opengis.metadata.distribution.DigitalTransferOptions;
import org.opengis.metadata.identification.Identification;
import org.opengis.metadata.identification.Resolution;
public class GeoNetworkInspector {
private String geonetworkUrl = "http://geoserver-dev2.d4science-ii.research-infrastructures.eu/geonetwork/";
// private String geonetworkUrl = "http://geoserver-last.d4science-ii.research-infrastructures.eu/geonetwork/";
// private String geonetworkUrl = "http://geoserver.d4science-ii.research-infrastructures.eu/geonetwork/";
private String geonetworkUser = "admin";
private String geonetworkPwd = "admin";
private String scope = "/gcube/devsec";
public String getScope() {
return scope;
}
public void setScope(String scope) {
this.scope = scope;
}
public static double getResolution(Metadata meta){
double res = 0;
try{
DefaultDataIdentification ddi = (DefaultDataIdentification) meta.getIdentificationInfo().iterator().next();
//take the lowest resolution
for (Resolution r:ddi.getSpatialResolutions()){
Double rr = r.getDistance();
if (rr ==null)
rr=r.getEquivalentScale().doubleValue();
if (rr!=null && rr>res){
res = rr;
}
}
}catch(Exception e){
e.printStackTrace();
AnalysisLogger.getLogger().debug("Could not get Data Identification");
}
AnalysisLogger.getLogger().debug("Calculated Resolution is:"+res);
return res;
}
public String getGeoserverLink(Metadata meta) {
String link = null;
String geoserverString = "/geoserver/";
String geoserverEndString = "/geoserver?";
String wmslink = getWMSLink(meta);
if (wmslink!=null){
int idx = wmslink.indexOf(geoserverString);
if (idx<0)
idx = wmslink.indexOf(geoserverEndString);
if (idx>0){
link = wmslink.substring(0,idx+geoserverString.length()-1);
return link;
}
}
String wfslink = getWFSLink(meta);
if (wfslink!=null){
int idx = wfslink.indexOf(geoserverString);
if (idx<0)
idx = wfslink.indexOf(geoserverEndString);
if (idx>0){
link = wfslink.substring(0,idx+geoserverString.length()-1);
return link;
}
}
String wcslink = getWCSLink(meta);
if (wcslink!=null){
int idx = wcslink.indexOf(geoserverString);
if (idx<0)
idx = wcslink.indexOf(geoserverEndString);
if (idx>0){
link = wcslink.substring(0,idx+geoserverString.length()-1);
return link;
}
}
if (link == null)
System.out.println("NO GEOSERVER LINK WAS FOUND ACCORDING TO THE CRITERION");
return link;
}
private String searchInUrl(Metadata meta, String criterion) {
String link = null;
for (DigitalTransferOptions option : meta.getDistributionInfo().getTransferOptions()) {
for (OnlineResource resource : option.getOnLines()) {
String tlink = "";
try{tlink = resource.getLinkage().toString();}catch(Exception e){}
if (tlink.toLowerCase().contains(criterion.toLowerCase())) {
link = tlink;
break;
}
}
}
if (link == null)
System.out.println("NO ONLINE LINK WAS FOUND ACCORDING TO THE CRITERION :" + criterion);
return link;
}
private String searchLayerNameInMeta(Metadata meta) {
String innerlayername = null;
for (DigitalTransferOptions option : meta.getDistributionInfo().getTransferOptions()) {
for (OnlineResource resource : option.getOnLines()) {
String layername = resource.getName();
String link = "";
try{
link = resource.getLinkage().toString().toLowerCase();
}catch(Exception e){}
if ((layername!=null)&&link.contains("wms")) {
innerlayername = layername;
break;
}
}
}
if (innerlayername == null)
System.out.println("NO LAYER NAME WAS FOUND IN TRANSFER OPTIONS");
return innerlayername;
}
public String getHttpLink(Metadata meta) {
return searchInUrl(meta, "http");
}
public String getWFSLink(Metadata meta) {
return searchInUrl(meta, "service=wfs");
}
// retrieves the wms link
public String getWMSLink(Metadata meta) {
return searchInUrl(meta, "service=wms");
}
public String getWCSLink(Metadata meta) {
return searchInUrl(meta, "service=wcs");
}
public String getOpenDapLink(Metadata meta) {
return searchInUrl(meta, "/dodsC");
}
public String getThreddsLink(Metadata meta) {
return searchInUrl(meta, "catalog.xml");
}
public String getLayerName(Metadata meta) {
AnalysisLogger.getLogger().debug("Retrieving Layer Name");
String wmslink = getWMSLink(meta);
String layer = null;
String finder = "layers=";
if (wmslink != null) {
AnalysisLogger.getLogger().debug("WMS layer found!");
int idxfinder = wmslink.indexOf(finder);
if (idxfinder > 0) {
AnalysisLogger.getLogger().debug("Searching for Layer Name inside the WMS Link");
wmslink = wmslink.substring(idxfinder);
int andIdx = wmslink.indexOf("&");
if (andIdx < 0)
andIdx = wmslink.length();
layer = wmslink.substring(finder.length(), andIdx).trim();
}
//if the layer is not inside the wmslink
else{
AnalysisLogger.getLogger().debug("Searching for Layer Name inside the file");
layer = searchLayerNameInMeta(meta);
}
}
return layer;
}
public boolean isNetCDFFile(Metadata meta) {
return (getOpenDapLink(meta) != null);
}
public boolean isAscFile(Metadata meta) {
String httplink = getHttpLink(meta);
return (httplink!=null && (httplink.endsWith(".asc")||httplink.endsWith(".ASC")));
}
public boolean isWFS(Metadata meta) {
String httplink = getWFSLink(meta);
return (httplink!=null);
}
Configuration gnconfiguration;
public GeoNetworkReader initGeoNetworkReader() throws Exception {
AnalysisLogger.getLogger().debug("Features Manager: configuring GeoNetwork");
if (scope!=null)
ScopeProvider.instance.set(scope);
else{
AnalysisLogger.getLogger().debug("Features Manager: Using manual configuration of GeoNetwork");
class CustomConfiguration implements Configuration{
@Override
public String getGeoNetworkEndpoint() {
return geonetworkUrl;
}
@Override
public Map<LoginLevel, String> getGeoNetworkPasswords() {
HashMap<LoginLevel, String> map = new HashMap<LoginLevel, String>();
map.put(LoginLevel.DEFAULT, geonetworkPwd);
return map;
}
@Override
public Map<LoginLevel, String> getGeoNetworkUsers() {
HashMap<LoginLevel, String> map = new HashMap<LoginLevel, String>();
map.put(LoginLevel.DEFAULT, geonetworkUser);
return map;
}
@Override
public int getScopeGroup() {
return 0;
}
}
ConfigurationManager.setConfiguration(CustomConfiguration.class);
}
AnalysisLogger.getLogger().debug("Initializing GeoNetwork");
GeoNetworkReader gn = GeoNetwork.get();
AnalysisLogger.getLogger().debug("Using the following Geonetwork: "+gn.getConfiguration().getGeoNetworkEndpoint()+" in scope "+scope);
return gn;
}
public String getGeonetworkURLFromScope() throws Exception {
GeoNetworkReader gn = initGeoNetworkReader();
return gn.getConfiguration().getGeoNetworkEndpoint();
}
public String getGeonetworkUserFromScope() throws Exception {
GeoNetworkReader gn = initGeoNetworkReader();
return gn.getConfiguration().getGeoNetworkUsers().get(LoginLevel.DEFAULT);
}
public String getGeonetworkPasswordFromScope() throws Exception {
GeoNetworkReader gn = initGeoNetworkReader();
return gn.getConfiguration().getGeoNetworkPasswords().get(LoginLevel.DEFAULT);
}
private Metadata getGNInfobyTitle(String info) throws Exception {
GeoNetworkReader gn = initGeoNetworkReader();
// Form query object
gn.login(LoginLevel.DEFAULT);
GNSearchRequest req = new GNSearchRequest();
req.addParam(GNSearchRequest.Param.title, info);
// req.addConfig(GNSearchRequest.Config.similarity, "1");
GNSearchResponse resp = gn.query(req);
Metadata meta = null;
if (resp.getCount() != 0)
for (GNSearchResponse.GNMetadata metadata : resp) {
try {
meta = gn.getById(metadata.getUUID());
break;
} catch (Exception e) {
AnalysisLogger.getLogger().debug("Error retrieving information for some metadata");
}
}
return meta;
}
public List<Metadata> getAllGNInfobyTitle(String info, String tolerance) throws Exception {
GeoNetworkReader gn = initGeoNetworkReader();
// Form query object
gn.login(LoginLevel.DEFAULT);
GNSearchRequest req = new GNSearchRequest();
req.addParam(GNSearchRequest.Param.title, info);
req.addConfig(GNSearchRequest.Config.similarity, tolerance);
GNSearchResponse resp = gn.query(req);
Metadata meta = null;
List<Metadata> metadatalist = new ArrayList<Metadata>();
if (resp.getCount() != 0)
for (GNSearchResponse.GNMetadata metadata : resp) {
try {
meta = gn.getById(metadata.getUUID());
metadatalist.add(meta);
} catch (Exception e) {
AnalysisLogger.getLogger().debug("Error retrieving information for some metadata");
}
}
return metadatalist;
}
public List<Metadata> getAllGNInfobyText(String info, String tolerance) throws Exception {
GeoNetworkReader gn = initGeoNetworkReader();
// Form query object
gn.login(LoginLevel.DEFAULT);
GNSearchRequest req = new GNSearchRequest();
req.addParam(GNSearchRequest.Param.any, info);
req.addConfig(GNSearchRequest.Config.similarity, tolerance);
GNSearchResponse resp = gn.query(req);
Metadata meta = null;
List<Metadata> metadatalist = new ArrayList<Metadata>();
if (resp.getCount() != 0)
for (GNSearchResponse.GNMetadata metadata : resp) {
try {
meta = gn.getById(metadata.getUUID());
metadatalist.add(meta);
} catch (Exception e) {
AnalysisLogger.getLogger().debug("Error retrieving information for some metadata");
}
}
return metadatalist;
}
private List<Metadata> getFastGNInfobyTitle(String info, String completeTitle, String tolerance) throws Exception {
GeoNetworkReader gn = initGeoNetworkReader();
// Form query object
gn.login(LoginLevel.DEFAULT);
GNSearchRequest req = new GNSearchRequest();
req.addParam(GNSearchRequest.Param.title, info);
req.addConfig(GNSearchRequest.Config.similarity, tolerance);
GNSearchResponse resp = gn.query(req);
Metadata meta = null;
List<Metadata> metadatalist = new ArrayList<Metadata>();
if (resp.getCount() != 0){
AnalysisLogger.getLogger().debug("Retrieving information ...");
for (GNSearchResponse.GNMetadata metadata : resp) {
try {
meta = gn.getById(metadata.getUUID());
Identification id = meta.getIdentificationInfo().iterator().next();
String title = id.getCitation().getTitle().toString();
if (title.equalsIgnoreCase(completeTitle)){
AnalysisLogger.getLogger().debug("Found UUID:"+metadata.getUUID());
metadatalist.add(meta);
break;
}
} catch (Exception e) {
AnalysisLogger.getLogger().debug("Error retrieving information for some metadata");
}
}
AnalysisLogger.getLogger().debug("Information Successfully Retrieved");
}
return metadatalist;
}
private Metadata getGNInfobyUUID(String UUID) throws Exception {
GeoNetworkReader gn = initGeoNetworkReader();
// Form query object
gn.login(LoginLevel.DEFAULT);
Metadata meta = gn.getById(UUID);
AnalysisLogger.getLogger().debug("Layer with UUID: "+UUID+" successfully Retrieved!");
return meta;
}
public Metadata getGNInfobyUUIDorName(String layerUUIDorTitle) throws Exception {
AnalysisLogger.getLogger().debug("MapsComparator: Getting layer with UUID..."+layerUUIDorTitle);
Metadata meta = null;
try{
meta = getGNInfobyUUID(layerUUIDorTitle);
}catch(Exception e){
AnalysisLogger.getLogger().debug("MapsComparator: Impossible to get layer as UUID");
}
if (meta==null){
AnalysisLogger.getLogger().debug("MapsComparator: NO UUID Available - Trying with NAME..."+layerUUIDorTitle);
try{
meta = checkForMetadatabyTitle(GeoNetworkInspector.treatTitleForGN(layerUUIDorTitle), layerUUIDorTitle);
}catch(Exception e){
throw new Exception("Layer does not exist");
}
}
return meta;
}
private Metadata checkForMetadatabyTitle(String searchString, String completetitle) throws Exception {
return checkForMetadatabyTitle(searchString, completetitle, "");
}
private Metadata checkForMetadatabyTitle(String searchString, String completetitle, String filename) throws Exception {
AnalysisLogger.getLogger().debug("Searching for: "+searchString);
List<Metadata> mlist = getFastGNInfobyTitle(searchString, completetitle,"1");
AnalysisLogger.getLogger().debug("Found:"+mlist.size()+" results");
Metadata mfound = null;
// DefaultInternationalString intfilename = new DefaultInternationalString(filename);
for (Metadata m : mlist) {
Identification id = m.getIdentificationInfo().iterator().next();
String title = id.getCitation().getTitle().toString();
if (completetitle.equalsIgnoreCase(title)) {
/*
Iterator<? extends Keywords> it = id.getDescriptiveKeywords().iterator();
while (it.hasNext()){
Keywords keys = (Keywords)it.next();
for (InternationalString is :keys.getKeywords()){
// System.out.println(is);
if (is.toString().equals(filename)){
mfound = m;
break;
}
}
if (mfound!=null)
break;
}
}
if (mfound!=null)
break;
*/
mfound = m;
break;
}
}
return mfound;
}
public String getGeonetworkUrl() {
return geonetworkUrl;
}
public void setGeonetworkUrl(String geonetworkUrl) {
this.geonetworkUrl = geonetworkUrl;
}
public String getGeonetworkUser() {
return geonetworkUser;
}
public void setGeonetworkUser(String geonetworkUser) {
this.geonetworkUser = geonetworkUser;
}
public String getGeonetworkPwd() {
return geonetworkPwd;
}
public void setGeonetworkPwd(String geonetworkPwd) {
this.geonetworkPwd = geonetworkPwd;
}
public static String treatTitleForGN(String origLayerTitle) {
String layerTitle = origLayerTitle.toLowerCase();
int idx = layerTitle.indexOf(" from [");
// int idx = layerTitle.indexOf(" "); //let's search among many layers
String layerTitle2 = layerTitle;
if (idx>0)
layerTitle2 = layerTitle.toLowerCase().substring(0, idx).trim();
else {
idx = layerTitle.indexOf(" in [");
if (idx>0)
layerTitle2 = layerTitle.toLowerCase().substring(0, idx).trim();
else{
idx = layerTitle.indexOf("(");
if (idx>0)
layerTitle2 = layerTitle.toLowerCase().substring(0, idx).trim();
}
}
layerTitle2 = layerTitle2.replaceAll("(\\(.*\\))", " ");
layerTitle2 = layerTitle2.replace("_", " ").replace("-", " ").replace("(", " ").replace(")", " ");
String punct = "[!\"#$%&'*+,./:;<=>?@\\^_`{|}~-]";
layerTitle2 = layerTitle2.replaceAll("( |^)+[^A-Za-z]+("+punct+")*[^A-Za-z]*", " ").trim();
return layerTitle2.replaceAll(punct, " ").replaceAll("( )+", " ");
}
public static void main1(String args[]) throws Exception {
// String title = "temperature (04091217ruc.nc)";
// String title = "Bathymetry";
// String title = "FAO aquatic species distribution map of Melanogrammus aeglefinus";
// String title = "geopotential height from [12/09/2004 19:00] to [12/09/2004 22:00] (04091217_ruc.nc)";
String title = "geopotential height";
GeoNetworkInspector fm = new GeoNetworkInspector();
Metadata meta = fm.getGNInfobyTitle(title);
System.out.println("is file? " + fm.isNetCDFFile(meta));
System.out.println("opendap: " + fm.getOpenDapLink(meta));
System.out.println("wcs:" + fm.getWCSLink(meta));
System.out.println("wms:" + fm.getWMSLink(meta));
System.out.println("thredds:" + fm.getThreddsLink(meta));
}
public static void main(String args[]) throws Exception {
System.out.println(treatTitleForGN("sea/land/lake/ice field composite mask from"));
}
}