|
|
|
@ -21,8 +21,8 @@ import org.gcube.informationsystem.model.reference.properties.Encrypted;
|
|
|
|
|
import org.gcube.informationsystem.model.reference.properties.Header;
|
|
|
|
|
import org.gcube.informationsystem.model.reference.relations.ConsistsOf;
|
|
|
|
|
import org.gcube.informationsystem.model.reference.relations.IsIdentifiedBy;
|
|
|
|
|
import org.gcube.informationsystem.resourceregistry.api.exceptions.AvailableInAnotherContextException;
|
|
|
|
|
import org.gcube.informationsystem.resourceregistry.api.exceptions.NotFoundException;
|
|
|
|
|
import org.gcube.informationsystem.resourceregistry.api.exceptions.entity.resource.ResourceAvailableInAnotherContextException;
|
|
|
|
|
import org.gcube.informationsystem.resourceregistry.api.exceptions.entity.resource.ResourceNotFoundException;
|
|
|
|
|
import org.gcube.informationsystem.utils.ISMapper;
|
|
|
|
|
import org.gcube.resourcemanagement.model.impl.entities.facets.AccessPointFacetImpl;
|
|
|
|
|
import org.gcube.resourcemanagement.model.impl.entities.facets.NetworkingFacetImpl;
|
|
|
|
@ -40,11 +40,11 @@ import org.slf4j.LoggerFactory;
|
|
|
|
|
import com.fasterxml.jackson.databind.node.ArrayNode;
|
|
|
|
|
import com.fasterxml.jackson.databind.node.ObjectNode;
|
|
|
|
|
|
|
|
|
|
public class ServiceEndpointExporter extends GCoreResourceMapper<ServiceEndpoint, EService> {
|
|
|
|
|
public class ServiceEndpointExporter extends GCoreResourceMapper<ServiceEndpoint,EService> {
|
|
|
|
|
|
|
|
|
|
private static Logger logger = LoggerFactory.getLogger(ServiceEndpointExporter.class);
|
|
|
|
|
|
|
|
|
|
public static final String FIXED_VERSION = "1.0.0";
|
|
|
|
|
public static final String FIXED_VERSION = "1.0.0";
|
|
|
|
|
|
|
|
|
|
public static final String PLATFORM = "PLATFORM";
|
|
|
|
|
public static final String POSITION = "POSITION";
|
|
|
|
@ -56,18 +56,18 @@ public class ServiceEndpointExporter extends GCoreResourceMapper<ServiceEndpoint
|
|
|
|
|
|
|
|
|
|
public static final String NAME = "name";
|
|
|
|
|
public static final String VALUE = "value";
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static final String ARRAY = "ARRAY";
|
|
|
|
|
public static final String PROPERTIES = "PROPERTIES";
|
|
|
|
|
|
|
|
|
|
public static final String NOT_URI_ENDPOINT = "NOT_URI_ENDPOINT";
|
|
|
|
|
|
|
|
|
|
public ServiceEndpointExporter(boolean filteredReport){
|
|
|
|
|
public ServiceEndpointExporter(boolean filteredReport) {
|
|
|
|
|
super(ServiceEndpoint.class, EService.class, filteredReport);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
protected EService map(ServiceEndpoint gr) throws Exception {
|
|
|
|
|
protected EService map(ServiceEndpoint gr) throws Exception {
|
|
|
|
|
Profile profile = gr.profile();
|
|
|
|
|
UUID uuid = UUID.fromString(gr.id());
|
|
|
|
|
boolean readFromIS = false;
|
|
|
|
@ -81,9 +81,9 @@ public class ServiceEndpointExporter extends GCoreResourceMapper<ServiceEndpoint
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
readFromIS = resourceRegistryClient.exists(rClass, uuid);
|
|
|
|
|
}catch (NotFoundException e) {
|
|
|
|
|
} catch(ResourceNotFoundException e) {
|
|
|
|
|
readFromIS = false;
|
|
|
|
|
}catch (AvailableInAnotherContextException e) {
|
|
|
|
|
} catch(ResourceAvailableInAnotherContextException e) {
|
|
|
|
|
resourceRegistryPublisher.addResourceToCurrentContext(EService.NAME, uuid);
|
|
|
|
|
Thread.sleep(100);
|
|
|
|
|
readFromIS = true;
|
|
|
|
@ -92,66 +92,66 @@ public class ServiceEndpointExporter extends GCoreResourceMapper<ServiceEndpoint
|
|
|
|
|
Group<AccessPoint> accessPoints = profile.accessPoints();
|
|
|
|
|
accessPointFacets = new AccessPointFacet[accessPoints.size()];
|
|
|
|
|
|
|
|
|
|
if(readFromIS){
|
|
|
|
|
if(readFromIS) {
|
|
|
|
|
eService = read(uuid);
|
|
|
|
|
//softwareFacet = (SoftwareFacet) eService.getIdentificationFacets().get(0);
|
|
|
|
|
|
|
|
|
|
List<ConsistsOf<? extends Resource, ? extends Facet>> consistsOfs = eService.getConsistsOf();
|
|
|
|
|
List<ConsistsOf<? extends Resource,? extends Facet>> consistsOfs = eService.getConsistsOf();
|
|
|
|
|
|
|
|
|
|
for(ConsistsOf<? extends Resource, ? extends Facet> c : consistsOfs){
|
|
|
|
|
for(ConsistsOf<? extends Resource,? extends Facet> c : consistsOfs) {
|
|
|
|
|
Facet target = c.getTarget();
|
|
|
|
|
if(c instanceof IsIdentifiedBy){
|
|
|
|
|
if(c instanceof IsIdentifiedBy) {
|
|
|
|
|
if(target instanceof SoftwareFacet) {
|
|
|
|
|
softwareFacet = (SoftwareFacet) target;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
if(target instanceof AccessPointFacet){
|
|
|
|
|
if(target instanceof AccessPointFacet) {
|
|
|
|
|
try {
|
|
|
|
|
Object positionObject = c.getAdditionalProperty(POSITION);
|
|
|
|
|
Integer position = Integer.valueOf(positionObject.toString());
|
|
|
|
|
if(position!=null){
|
|
|
|
|
if(position != null) {
|
|
|
|
|
accessPointFacets[position] = (AccessPointFacet) target;
|
|
|
|
|
}
|
|
|
|
|
}catch (Exception e) {
|
|
|
|
|
} catch(Exception e) {
|
|
|
|
|
// Position is used on relation to match the AccessPoint on ServiceEndpoint
|
|
|
|
|
logger.error("No POSITION found", e);
|
|
|
|
|
}
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if(target instanceof SoftwareFacet){
|
|
|
|
|
if(target instanceof SoftwareFacet) {
|
|
|
|
|
SoftwareFacet targetSoftwareFacet = (SoftwareFacet) target;
|
|
|
|
|
if(targetSoftwareFacet.getGroup().compareTo(PLATFORM)==0){
|
|
|
|
|
if(targetSoftwareFacet.getGroup().compareTo(PLATFORM) == 0) {
|
|
|
|
|
platformSoftwareFacet = targetSoftwareFacet;
|
|
|
|
|
}
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if(target instanceof ServiceStateFacet){
|
|
|
|
|
if(target instanceof ServiceStateFacet) {
|
|
|
|
|
serviceStateFacet = (ServiceStateFacet) target;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if(target instanceof NetworkingFacet){
|
|
|
|
|
if(target instanceof NetworkingFacet) {
|
|
|
|
|
networkingFacet = (NetworkingFacet) target;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}else{
|
|
|
|
|
} else {
|
|
|
|
|
eService = new EServiceImpl();
|
|
|
|
|
Header header = new HeaderImpl(uuid);
|
|
|
|
|
eService.setHeader(header);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* ----------------------------------------- */
|
|
|
|
|
if(softwareFacet==null){
|
|
|
|
|
if(softwareFacet == null) {
|
|
|
|
|
softwareFacet = new SoftwareFacetImpl();
|
|
|
|
|
IsIdentifiedBy<EService, SoftwareFacet> identifiedBy =
|
|
|
|
|
new IsIdentifiedByImpl<EService, SoftwareFacet>(eService, softwareFacet, null);
|
|
|
|
|
IsIdentifiedBy<EService,SoftwareFacet> identifiedBy = new IsIdentifiedByImpl<EService,SoftwareFacet>(
|
|
|
|
|
eService, softwareFacet, null);
|
|
|
|
|
eService.addFacet(identifiedBy);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -159,78 +159,75 @@ public class ServiceEndpointExporter extends GCoreResourceMapper<ServiceEndpoint
|
|
|
|
|
softwareFacet.setName(profile.name());
|
|
|
|
|
softwareFacet.setVersion(FIXED_VERSION);
|
|
|
|
|
String description = profile.description();
|
|
|
|
|
if(description!=null && description.compareTo("")!=0){
|
|
|
|
|
if(description != null && description.compareTo("") != 0) {
|
|
|
|
|
softwareFacet.setDescription(getStringAsUTF8(description));
|
|
|
|
|
}
|
|
|
|
|
/* ----------------------------------------- */
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* ----------------------------------------- */
|
|
|
|
|
Platform platform = profile.platform();
|
|
|
|
|
|
|
|
|
|
if(platformSoftwareFacet==null){
|
|
|
|
|
|
|
|
|
|
if(platformSoftwareFacet == null) {
|
|
|
|
|
platformSoftwareFacet = new SoftwareFacetImpl();
|
|
|
|
|
eService.addFacet(platformSoftwareFacet);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
platformSoftwareFacet.setGroup(PLATFORM);
|
|
|
|
|
platformSoftwareFacet.setName(platform.name());
|
|
|
|
|
String platformVersion = String.format("%d.%d.%d-%d",
|
|
|
|
|
platform.version(), platform.minorVersion(),
|
|
|
|
|
String platformVersion = String.format("%d.%d.%d-%d", platform.version(), platform.minorVersion(),
|
|
|
|
|
platform.revisionVersion(), platform.buildVersion());
|
|
|
|
|
softwareFacet.setVersion(platformVersion);
|
|
|
|
|
/* ----------------------------------------- */
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* ----------------------------------------- */
|
|
|
|
|
Runtime runTime = profile.runtime();
|
|
|
|
|
|
|
|
|
|
if(serviceStateFacet==null){
|
|
|
|
|
if(serviceStateFacet == null) {
|
|
|
|
|
serviceStateFacet = new ServiceStateFacetImpl();
|
|
|
|
|
eService.addFacet(serviceStateFacet);
|
|
|
|
|
}
|
|
|
|
|
serviceStateFacet.setValue(runTime.status());
|
|
|
|
|
|
|
|
|
|
if(networkingFacet==null){
|
|
|
|
|
if(networkingFacet == null) {
|
|
|
|
|
networkingFacet = new NetworkingFacetImpl();
|
|
|
|
|
eService.addFacet(networkingFacet);
|
|
|
|
|
}
|
|
|
|
|
networkingFacet.setHostName(runTime.hostedOn());
|
|
|
|
|
String ghnID = runTime.ghnId();
|
|
|
|
|
if(ghnID!=null && ghnID.compareTo("")!=0){
|
|
|
|
|
if(ghnID != null && ghnID.compareTo("") != 0) {
|
|
|
|
|
networkingFacet.setAdditionalProperty(GHN_ID, ghnID);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* ----------------------------------------- */
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* ----------------------------------------- */
|
|
|
|
|
int i=0;
|
|
|
|
|
for(AccessPoint accessPoint : accessPoints){
|
|
|
|
|
if(accessPointFacets[i] == null){
|
|
|
|
|
int i = 0;
|
|
|
|
|
for(AccessPoint accessPoint : accessPoints) {
|
|
|
|
|
if(accessPointFacets[i] == null) {
|
|
|
|
|
accessPointFacets[i] = new AccessPointFacetImpl();
|
|
|
|
|
ConsistsOf<EService, AccessPointFacet> consistsOf = new ConsistsOfImpl<EService, AccessPointFacet>(eService, accessPointFacets[i], null);
|
|
|
|
|
ConsistsOf<EService,AccessPointFacet> consistsOf = new ConsistsOfImpl<EService,AccessPointFacet>(
|
|
|
|
|
eService, accessPointFacets[i], null);
|
|
|
|
|
consistsOf.setAdditionalProperty(POSITION, i);
|
|
|
|
|
eService.addFacet(consistsOf);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
accessPointFacets[i].setEntryName(accessPoint.name());
|
|
|
|
|
String address = accessPoint.address();
|
|
|
|
|
if(address!=null && address.compareTo("")!=0){
|
|
|
|
|
if(address != null && address.compareTo("") != 0) {
|
|
|
|
|
try {
|
|
|
|
|
URI uri = URI.create(address);
|
|
|
|
|
accessPointFacets[i].setEndpoint(uri);
|
|
|
|
|
}catch (IllegalArgumentException e) {
|
|
|
|
|
} catch(IllegalArgumentException e) {
|
|
|
|
|
accessPointFacets[i].setAdditionalProperty(NOT_URI_ENDPOINT, address);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
String accessPointDescription = accessPoint.description();
|
|
|
|
|
if(accessPointDescription!=null && accessPointDescription.compareTo("")!=0){
|
|
|
|
|
if(accessPointDescription != null && accessPointDescription.compareTo("") != 0) {
|
|
|
|
|
accessPointFacets[i].setDescription(getStringAsUTF8(accessPointDescription));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Managing Username and Password */
|
|
|
|
|
/* Managing Username and Password */
|
|
|
|
|
try {
|
|
|
|
|
String username = accessPoint.username();
|
|
|
|
|
String passwordString = accessPoint.password();
|
|
|
|
@ -238,15 +235,14 @@ public class ServiceEndpointExporter extends GCoreResourceMapper<ServiceEndpoint
|
|
|
|
|
password.setEncryptedValue(passwordString);
|
|
|
|
|
accessPointFacets[i].setAdditionalProperty(USERNAME, username);
|
|
|
|
|
accessPointFacets[i].setAdditionalProperty(PASSWORD, password);
|
|
|
|
|
}catch (NullPointerException e) {
|
|
|
|
|
} catch(NullPointerException e) {
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
/* END Managing Username and Password */
|
|
|
|
|
|
|
|
|
|
/* END Managing Username and Password */
|
|
|
|
|
|
|
|
|
|
/* Managing AccessPoint Properties */
|
|
|
|
|
Group<Property> properties = accessPoint.properties();
|
|
|
|
|
if(properties!=null && properties.size()>0){
|
|
|
|
|
if(properties != null && properties.size() > 0) {
|
|
|
|
|
ObjectNode propertiesObjectNode = ISMapper.getObjectMapper().createObjectNode();
|
|
|
|
|
/*
|
|
|
|
|
* List/Set support is currently disabled due to OrientDB bug see https://github.com/orientechnologies/orientdb/issues/7354
|
|
|
|
@ -254,7 +250,7 @@ public class ServiceEndpointExporter extends GCoreResourceMapper<ServiceEndpoint
|
|
|
|
|
// This is a workaround
|
|
|
|
|
ArrayNode arrayNode = propertiesObjectNode.putArray(ARRAY);
|
|
|
|
|
|
|
|
|
|
for(Property property : properties){
|
|
|
|
|
for(Property property : properties) {
|
|
|
|
|
ObjectNode objectNode = ISMapper.getObjectMapper().createObjectNode();
|
|
|
|
|
objectNode.put(NAME, property.name());
|
|
|
|
|
boolean encryptedValue = property.isEncrypted();
|
|
|
|
@ -262,7 +258,7 @@ public class ServiceEndpointExporter extends GCoreResourceMapper<ServiceEndpoint
|
|
|
|
|
Encrypted encrypted = new EncryptedImpl();
|
|
|
|
|
encrypted.setEncryptedValue(property.value());
|
|
|
|
|
objectNode.put(VALUE, encryptedValue);
|
|
|
|
|
}else {
|
|
|
|
|
} else {
|
|
|
|
|
objectNode.put(VALUE, property.value());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -277,8 +273,7 @@ public class ServiceEndpointExporter extends GCoreResourceMapper<ServiceEndpoint
|
|
|
|
|
}
|
|
|
|
|
/* ----------------------------------------- */
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return eService;
|
|
|
|
|
return eService;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|