From 1a27b8a43ea79fc6a760cf6760c2934d118fc17d Mon Sep 17 00:00:00 2001 From: mariateresa Date: Wed, 17 Apr 2024 18:04:40 +0200 Subject: [PATCH] adding logic and GUIs for creation and removal of other types --- .../service/InformationSystemService.java | 6 +- .../service/dto/EServiceDTO.java | 5 +- .../service/dto/HostingNodeDTO.java | 5 +- .../service/dto/ResourceImplDTO.java | 14 +++ .../service/dto/VirtualMachineDTO.java | 14 +++ .../service/dto/VirtualServiceDTO.java | 5 +- .../service/dto/angular/ExtraProps.java | 26 ---- .../dto/angular/VirtualServiceAngular.java | 119 ------------------ .../informationsystem/web/rest/Constants.java | 1 + .../web/rest/DTOResourceBuilder.java | 57 ++++++--- .../informationsystem/web/rest/ExtraProp.java | 16 --- .../web/rest/FacetPropertyGroup.java | 20 --- .../web/rest/FormDataJson.java | 47 +++++++ .../web/rest/InformationSystemResource.java | 38 +++--- .../facet-editor/facet-editor.component.html | 1 - src/main/webapp/app/home/home.component.html | 3 + .../webapp/app/services/i-virtual-machine.ts | 9 ++ .../app/services/resources-impl.service.ts | 5 + .../app/shared/facet-model/BaseFacet.ts | 18 +++ .../app/shared/facet-model/CustomProperty.ts | 12 ++ .../app/shared/facet-model/SoftwareFacet.ts | 22 ++++ .../table-screen-es.component.spec.ts | 23 ---- .../table-screen-vs.component.scss | 0 .../table-screen-vs/table-screen-vs.module.ts | 1 - .../table-screen/table-screen.component.ts | 1 + 25 files changed, 220 insertions(+), 248 deletions(-) create mode 100644 src/main/java/org/gcube/informationsystem/service/dto/ResourceImplDTO.java create mode 100644 src/main/java/org/gcube/informationsystem/service/dto/VirtualMachineDTO.java delete mode 100644 src/main/java/org/gcube/informationsystem/service/dto/angular/ExtraProps.java delete mode 100644 src/main/java/org/gcube/informationsystem/service/dto/angular/VirtualServiceAngular.java delete mode 100644 src/main/java/org/gcube/informationsystem/web/rest/ExtraProp.java delete mode 100644 src/main/java/org/gcube/informationsystem/web/rest/FacetPropertyGroup.java create mode 100644 src/main/java/org/gcube/informationsystem/web/rest/FormDataJson.java create mode 100644 src/main/webapp/app/services/i-virtual-machine.ts create mode 100644 src/main/webapp/app/shared/facet-model/BaseFacet.ts create mode 100644 src/main/webapp/app/shared/facet-model/CustomProperty.ts create mode 100644 src/main/webapp/app/shared/facet-model/SoftwareFacet.ts delete mode 100644 src/main/webapp/app/table-screen-es/table-screen-es.component.spec.ts delete mode 100644 src/main/webapp/app/table-screen-vs/table-screen-vs.component.scss diff --git a/src/main/java/org/gcube/informationsystem/service/InformationSystemService.java b/src/main/java/org/gcube/informationsystem/service/InformationSystemService.java index 9ec3343..f01ca3f 100644 --- a/src/main/java/org/gcube/informationsystem/service/InformationSystemService.java +++ b/src/main/java/org/gcube/informationsystem/service/InformationSystemService.java @@ -45,6 +45,7 @@ import org.slf4j.LoggerFactory; import org.springframework.stereotype.Service; import com.jayway.jsonpath.JsonPath; +import com.jayway.jsonpath.internal.filter.ValueNode.JsonNode; import com.nimbusds.jose.shaded.json.JSONUtil; import net.minidev.json.JSONArray; @@ -402,7 +403,10 @@ public class InformationSystemService { public void createResourceInstance(String jsonDescription) throws Exception { String currentCtx = SecretManagerProvider.instance.get().getContext(); ResourceRegistryPublisher publisher = ResourceRegistryPublisherFactory.create(currentCtx); - publisher.createResource(jsonDescription); + String res = publisher.createResource(jsonDescription); + System.out.println("*************RES*********"); + System.out.println(res); + System.out.println("**********************"); } //CRUD - 2 diff --git a/src/main/java/org/gcube/informationsystem/service/dto/EServiceDTO.java b/src/main/java/org/gcube/informationsystem/service/dto/EServiceDTO.java index b0e7fba..8f7b698 100644 --- a/src/main/java/org/gcube/informationsystem/service/dto/EServiceDTO.java +++ b/src/main/java/org/gcube/informationsystem/service/dto/EServiceDTO.java @@ -8,10 +8,7 @@ import lombok.NoArgsConstructor; @Data @AllArgsConstructor @NoArgsConstructor -public class EServiceDTO { - private String id; - private String lastMod; - private String name; +public class EServiceDTO extends ResourceImplDTO{ private String artifact; private String version; private String group; diff --git a/src/main/java/org/gcube/informationsystem/service/dto/HostingNodeDTO.java b/src/main/java/org/gcube/informationsystem/service/dto/HostingNodeDTO.java index 89c1425..fb03e17 100644 --- a/src/main/java/org/gcube/informationsystem/service/dto/HostingNodeDTO.java +++ b/src/main/java/org/gcube/informationsystem/service/dto/HostingNodeDTO.java @@ -8,10 +8,7 @@ import lombok.NoArgsConstructor; @Data @AllArgsConstructor @NoArgsConstructor -public class HostingNodeDTO { - private String id; - private String lastMod; - private String name; +public class HostingNodeDTO extends ResourceImplDTO{ private String status; private String avMemory; private String hdSpace; diff --git a/src/main/java/org/gcube/informationsystem/service/dto/ResourceImplDTO.java b/src/main/java/org/gcube/informationsystem/service/dto/ResourceImplDTO.java new file mode 100644 index 0000000..5c67b91 --- /dev/null +++ b/src/main/java/org/gcube/informationsystem/service/dto/ResourceImplDTO.java @@ -0,0 +1,14 @@ +package org.gcube.informationsystem.service.dto; + +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; + +@Data +@AllArgsConstructor +@NoArgsConstructor +public class ResourceImplDTO { + private String id; + private String lastMod; + private String name; +} diff --git a/src/main/java/org/gcube/informationsystem/service/dto/VirtualMachineDTO.java b/src/main/java/org/gcube/informationsystem/service/dto/VirtualMachineDTO.java new file mode 100644 index 0000000..a099304 --- /dev/null +++ b/src/main/java/org/gcube/informationsystem/service/dto/VirtualMachineDTO.java @@ -0,0 +1,14 @@ +package org.gcube.informationsystem.service.dto; + + +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; + +@Data +@AllArgsConstructor +@NoArgsConstructor +public class VirtualMachineDTO extends ResourceImplDTO{ + private String group; + private String version; +} diff --git a/src/main/java/org/gcube/informationsystem/service/dto/VirtualServiceDTO.java b/src/main/java/org/gcube/informationsystem/service/dto/VirtualServiceDTO.java index da1cbd1..6ccf238 100644 --- a/src/main/java/org/gcube/informationsystem/service/dto/VirtualServiceDTO.java +++ b/src/main/java/org/gcube/informationsystem/service/dto/VirtualServiceDTO.java @@ -8,10 +8,7 @@ import lombok.NoArgsConstructor; @Data @AllArgsConstructor @NoArgsConstructor -public class VirtualServiceDTO { - private String id; - private String lastMod; - private String name; +public class VirtualServiceDTO extends ResourceImplDTO{ private String group; private String version; } diff --git a/src/main/java/org/gcube/informationsystem/service/dto/angular/ExtraProps.java b/src/main/java/org/gcube/informationsystem/service/dto/angular/ExtraProps.java deleted file mode 100644 index 4bf9079..0000000 --- a/src/main/java/org/gcube/informationsystem/service/dto/angular/ExtraProps.java +++ /dev/null @@ -1,26 +0,0 @@ -package org.gcube.informationsystem.service.dto.angular; - -class ExtraProps{ - String prop_deno; - public String getProp_deno() { - return prop_deno; - } - public void setProp_deno(String prop_deno) { - this.prop_deno = prop_deno; - } - public String getProp_val() { - return prop_val; - } - public void setProp_val(String prop_val) { - this.prop_val = prop_val; - } - public String getProp_tipo() { - return prop_tipo; - } - public void setProp_tipo(String prop_tipo) { - this.prop_tipo = prop_tipo; - } - String prop_val; - String prop_tipo; - -} diff --git a/src/main/java/org/gcube/informationsystem/service/dto/angular/VirtualServiceAngular.java b/src/main/java/org/gcube/informationsystem/service/dto/angular/VirtualServiceAngular.java deleted file mode 100644 index 087b76d..0000000 --- a/src/main/java/org/gcube/informationsystem/service/dto/angular/VirtualServiceAngular.java +++ /dev/null @@ -1,119 +0,0 @@ -package org.gcube.informationsystem.service.dto.angular; - -import java.util.ArrayList; - - -public class VirtualServiceAngular{ - String typeName; - ArrayList facets; - public String getTypeName() { - return typeName; - } - public void setTypeName(String typeName) { - this.typeName = typeName; - } - public ArrayList getFacets() { - return facets; - } - public void setFacets(ArrayList facets) { - this.facets = facets; - } -} - -class FacetDescription{ - //da elminare - begin - String facetName; - String max; - String min; - String facetDescription; - String relationFacet; - boolean isAdded; - boolean prop_optional; - //da elminare - end - String prop_name; - String prop_group; - String prop_description; - String prop_version; - String prop_qualifier; - ArrayList extraProps; - - public String getFacetName() { - return facetName; - } - public void setFacetName(String facetName) { - this.facetName = facetName; - } - public String getMax() { - return max; - } - public void setMax(String max) { - this.max = max; - } - public String getMin() { - return min; - } - public void setMin(String min) { - this.min = min; - } - public String getFacetDescription() { - return facetDescription; - } - public void setFacetDescription(String facetDescription) { - this.facetDescription = facetDescription; - } - public String getRelationFacet() { - return relationFacet; - } - public void setRelationFacet(String relationFacet) { - this.relationFacet = relationFacet; - } - public boolean isAdded() { - return isAdded; - } - public void setAdded(boolean isAdded) { - this.isAdded = isAdded; - } - public boolean isProp_optional() { - return prop_optional; - } - public void setProp_optional(boolean prop_optional) { - this.prop_optional = prop_optional; - } - public String getProp_name() { - return prop_name; - } - public void setProp_name(String prop_name) { - this.prop_name = prop_name; - } - public String getProp_group() { - return prop_group; - } - public void setProp_group(String prop_group) { - this.prop_group = prop_group; - } - public String getProp_description() { - return prop_description; - } - public void setProp_description(String prop_description) { - this.prop_description = prop_description; - } - public String getProp_version() { - return prop_version; - } - public void setProp_version(String prop_version) { - this.prop_version = prop_version; - } - public String getProp_qualifier() { - return prop_qualifier; - } - public void setProp_qualifier(String prop_qualifier) { - this.prop_qualifier = prop_qualifier; - } - public ArrayList getExtraProps() { - return extraProps; - } - public void setExtraProps(ArrayList extraProps) { - this.extraProps = extraProps; - } -} - diff --git a/src/main/java/org/gcube/informationsystem/web/rest/Constants.java b/src/main/java/org/gcube/informationsystem/web/rest/Constants.java index 76a91f6..ccae1cb 100644 --- a/src/main/java/org/gcube/informationsystem/web/rest/Constants.java +++ b/src/main/java/org/gcube/informationsystem/web/rest/Constants.java @@ -7,6 +7,7 @@ public final class Constants { public static final String RES_TYPE_HOSTINGNODE = "HostingNode"; public static final String RES_TYPE_ESERVICE = "EService"; public static final String RES_TYPE_VSERVICE = "VirtualService"; + public static final String RES_TYPE_VMACHINE = "VirtualMachine"; public static final String FACET_NETWORKING = "NetworkingFacet"; diff --git a/src/main/java/org/gcube/informationsystem/web/rest/DTOResourceBuilder.java b/src/main/java/org/gcube/informationsystem/web/rest/DTOResourceBuilder.java index be73a2d..3914178 100644 --- a/src/main/java/org/gcube/informationsystem/web/rest/DTOResourceBuilder.java +++ b/src/main/java/org/gcube/informationsystem/web/rest/DTOResourceBuilder.java @@ -33,15 +33,15 @@ public class DTOResourceBuilder { //private static String //hostingNodes JSONPath queries - private static String HN_DOMAIN_HOST_QUERY = "$..consistsOf[?(@.expectedtype=='IsIdentifiedBy')]['target'][?(@.['expectedtype']=='NetworkingFacet')].['domainName','hostName']"; - private static String HN_MEMORY_QUERY = "$..consistsOf[?(@.['type']=='ConsistsOf' && @.['expectedtype']=='HasPersistentMemory')].['target'].['expectedtype','unit','size','used']"; - private static String HN_STATUS_QUERY = "$..consistsOf[?(@.['target'])]*[?(@.['expectedtype']=='StateFacet')].['value']"; - private static String HN_VOL_MEMORY_QUERY = "$..consistsOf[?(@.['expectedtype']=='HasVolatileMemory')].['target'].['size','unit']"; + private static String NETWORKINGFACET_QUERY_DOMAIN = "$..consistsOf[?(@.expectedtype=='IsIdentifiedBy')]['target'][?(@.['expectedtype']=='NetworkingFacet')].['domainName','hostName']"; + private static String PERS_MEMORY_QUERY = "$..consistsOf[?(@.['type']=='ConsistsOf' && @.['expectedtype']=='HasPersistentMemory')].['target'].['expectedtype','unit','size','used']"; + private static String STATEFACET_QUERY_STATUS = "$..consistsOf[?(@.['target'])]*[?(@.['expectedtype']=='StateFacet')].['value']"; + private static String VOLATILE_MEMORY_QUERY = "$..consistsOf[?(@.['expectedtype']=='HasVolatileMemory')].['target'].['size','unit']"; //EService - private static String ES_ENDPOINT_QUERY = "$..consistsOf[*]['target'][?(@.['expectedtype']=='AccessPointFacet')].['endpoint','entryName']"; - private static String ES_STATUS_QUERY = "$..consistsOf[*]['target'][?(@.['expectedtype']=='StateFacet')].['value']"; - private static String ES_NGV_QUERY = "$..consistsOf[*]['target'][?(@.['expectedtype']=='SoftwareFacet')].['name','group','version']"; + private static String ACCESSPOINTFACET_QUERY_ENDPOINT = "$..consistsOf[*]['target'][?(@.['expectedtype']=='AccessPointFacet')].['endpoint','entryName']"; + private static String STATEFACET_QUERY_VALUE = "$..consistsOf[*]['target'][?(@.['expectedtype']=='StateFacet')].['value']"; + private static String SOFTWAREFACET_QUERY_NAME = "$..consistsOf[*]['target'][?(@.['expectedtype']=='SoftwareFacet')].['name','group','version']"; //VirtualService /* @@ -81,15 +81,15 @@ public class DTOResourceBuilder { ((HostingNodeDTO) dto).setLastMod(lastUpd); log.debug("2..."+lastUpd); - myLeaves = JsonPath.parse(resJson).read(HN_DOMAIN_HOST_QUERY); + myLeaves = JsonPath.parse(resJson).read(NETWORKINGFACET_QUERY_DOMAIN); ((HostingNodeDTO) dto).setName(myLeaves.get(0).get("hostName").toString()); log.debug("3..." + myLeaves.get(0).get("hostName").toString()); - myLeaves = JsonPath.parse(resJson).read(HN_MEMORY_QUERY); + myLeaves = JsonPath.parse(resJson).read(PERS_MEMORY_QUERY); ((HostingNodeDTO) dto).setAvMemory(myLeaves.get(0).get("size").toString()+" "+myLeaves.get(0).get("unit").toString()); log.debug("4..."+myLeaves.get(0).get("size").toString()+" "+myLeaves.get(0).get("unit").toString()); Object status = null; - status = JsonPath.parse(resJson).read(HN_STATUS_QUERY); + status = JsonPath.parse(resJson).read(STATEFACET_QUERY_STATUS); status = status.toString().replace("[\"", "").replace("\"]", ""); log.debug("5..."+status); ((HostingNodeDTO) dto).setStatus(status.toString()); @@ -98,7 +98,7 @@ public class DTOResourceBuilder { log.error("Error while building HostingNodeDTO from json"); e.printStackTrace(); } - myLeaves = JsonPath.parse(resJson).read(HN_VOL_MEMORY_QUERY); + myLeaves = JsonPath.parse(resJson).read(VOLATILE_MEMORY_QUERY); ((HostingNodeDTO) dto).setHdSpace(myLeaves.get(0).get("size").toString()+" "+myLeaves.get(0).get("unit").toString()); break; @@ -115,7 +115,7 @@ public class DTOResourceBuilder { ((EServiceDTO) dto).setLastMod(lastUpd); log.debug("2..."+lastUpd); - myLeaves= JsonPath.parse(resJson).read(ES_ENDPOINT_QUERY); + myLeaves= JsonPath.parse(resJson).read(ACCESSPOINTFACET_QUERY_ENDPOINT); String ep = myLeaves.get(0).get("endpoint").toString(); String en = myLeaves.get(0).get("entryName").toString(); @@ -124,7 +124,7 @@ public class DTOResourceBuilder { log.debug("3..."+ep); log.debug("3..."+en); - myLeaves = JsonPath.parse(resJson).read(ES_NGV_QUERY); + myLeaves = JsonPath.parse(resJson).read(SOFTWAREFACET_QUERY_NAME); String name = myLeaves.get(0).get("name").toString(); String group = myLeaves.get(0).get("group").toString(); String version = myLeaves.get(0).get("version").toString(); @@ -134,7 +134,7 @@ public class DTOResourceBuilder { ((EServiceDTO) dto).setGroup(group); - myLeaves = JsonPath.parse(resJson).read(ES_STATUS_QUERY); + myLeaves = JsonPath.parse(resJson).read(STATEFACET_QUERY_VALUE); String sts = myLeaves.toString().replace("[\"", "").replace("\"]", ""); log.debug("4..."+sts); ((EServiceDTO) dto).setStatus(sts); @@ -146,6 +146,33 @@ public class DTOResourceBuilder { } break; + case Constants.RES_TYPE_VMACHINE: + dto = new VirtualServiceDTO(); + try { + String uid= JsonPath.parse(resJson).read(UID_QUERY); + ((VirtualServiceDTO) dto).setId(uid); + log.debug("1..."+uid); + + String lastUpd= JsonPath.parse(resJson).read(LAST_UPDATE_QUERY); + lastUpd = lastUpd.substring(0,lastUpd.length()-10); + ((VirtualServiceDTO) dto).setLastMod(lastUpd); + log.debug("2..."+lastUpd); + + //Software Facet Fields + myLeaves = JsonPath.parse(resJson).read(SOFTWAREFACET_QUERY_NAME); + String name = myLeaves.get(0).get("name").toString(); + String group = myLeaves.get(0).get("group").toString(); + String version = myLeaves.get(0).get("version").toString(); + log.debug("3..."+myLeaves); + ((VirtualServiceDTO) dto).setVersion(version); + ((VirtualServiceDTO) dto).setName(name); + ((VirtualServiceDTO) dto).setGroup(group); + + }catch(Exception e) { + log.error("Error while building VirtualServiceDTO from json"); + e.printStackTrace(); + } + break; case Constants.RES_TYPE_VSERVICE: dto = new VirtualServiceDTO(); try { @@ -159,7 +186,7 @@ public class DTOResourceBuilder { log.debug("2..."+lastUpd); //Software Facet Fields - myLeaves = JsonPath.parse(resJson).read(ES_NGV_QUERY); + myLeaves = JsonPath.parse(resJson).read(SOFTWAREFACET_QUERY_NAME); String name = myLeaves.get(0).get("name").toString(); String group = myLeaves.get(0).get("group").toString(); String version = myLeaves.get(0).get("version").toString(); diff --git a/src/main/java/org/gcube/informationsystem/web/rest/ExtraProp.java b/src/main/java/org/gcube/informationsystem/web/rest/ExtraProp.java deleted file mode 100644 index daf4afd..0000000 --- a/src/main/java/org/gcube/informationsystem/web/rest/ExtraProp.java +++ /dev/null @@ -1,16 +0,0 @@ -package org.gcube.informationsystem.web.rest; - -import lombok.AllArgsConstructor; -import lombok.Data; -import lombok.NoArgsConstructor; - -@Data -@AllArgsConstructor -@NoArgsConstructor -public class ExtraProp { - - String prop_deno; - String prop_val; - String prop_tipo; - -} diff --git a/src/main/java/org/gcube/informationsystem/web/rest/FacetPropertyGroup.java b/src/main/java/org/gcube/informationsystem/web/rest/FacetPropertyGroup.java deleted file mode 100644 index 6192868..0000000 --- a/src/main/java/org/gcube/informationsystem/web/rest/FacetPropertyGroup.java +++ /dev/null @@ -1,20 +0,0 @@ -package org.gcube.informationsystem.web.rest; - -import java.util.LinkedHashMap; -import java.util.Map; - -import com.fasterxml.jackson.annotation.JsonAnySetter; - -//Risorsa da inviare per la creazione -public class FacetProperties { - String type; - Map facetprops = new LinkedHashMap(); - - @JsonAnySetter - void setDetail(String key, Object value) { - facetprops.put(key, value); - } - -} - - diff --git a/src/main/java/org/gcube/informationsystem/web/rest/FormDataJson.java b/src/main/java/org/gcube/informationsystem/web/rest/FormDataJson.java new file mode 100644 index 0000000..fb68441 --- /dev/null +++ b/src/main/java/org/gcube/informationsystem/web/rest/FormDataJson.java @@ -0,0 +1,47 @@ +package org.gcube.informationsystem.web.rest; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.LinkedHashMap; +import java.util.Map; + +import com.fasterxml.jackson.annotation.JsonAnySetter; + +//Risorsa da inviare per la creazione +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; + +public class FormDataJson { + private Map properties; + private Map extraProperties; + public FormDataJson(){ + properties = new HashMap<>(); + extraProperties = new HashMap<>(); + } + + @JsonAnySetter + public void addProperty(String property, String value){ + properties.put(property, value); + } + @JsonAnySetter + public void addExtraProperty(String extraProp, String value){ + properties.put(extraProp, value); + } +} + + +/* +class Student { +private Map properties; +public Student(){ + properties = new HashMap<>(); +} +public Map getProperties(){ + return properties; +} +@JsonAnySetter +public void add(String property, String value){ + properties.put(property, value); +} +}*/ \ No newline at end of file diff --git a/src/main/java/org/gcube/informationsystem/web/rest/InformationSystemResource.java b/src/main/java/org/gcube/informationsystem/web/rest/InformationSystemResource.java index 4c86658..9a5868b 100644 --- a/src/main/java/org/gcube/informationsystem/web/rest/InformationSystemResource.java +++ b/src/main/java/org/gcube/informationsystem/web/rest/InformationSystemResource.java @@ -229,7 +229,7 @@ public class InformationSystemResource { } }catch(Exception e) { log.error("ERROR WHILE FILLING RESOURCEIMPL DTO"); - //e.printStackTrace(); + e.printStackTrace(); } try { ObjectMapper objectMapper = new ObjectMapper(); @@ -242,27 +242,37 @@ public class InformationSystemResource { } } - //CRUD - 1 - @PostMapping("/createresource") - String createresource(@RequestParam String resourceType, @RequestBody String formData) throws Exception { - /* - * ResourceRegistryPublisher publisher = ResourceRegistryPublisherFactory.create(); - UUIDUtility uuidUtil = new UUIDUtility(); - return publisher.deleteResource(resourceType, uuidUtil.fromString(uuid)); - */ + //CRUD - 1 + @PostMapping("/createresource") + String createresource(@RequestParam String resourceType, @RequestBody String formData) throws Exception { + String currentContext = SecretManagerProvider.instance.get().getContext(); + String result = ""; + informationSystemService.setUma(createUmaToken(currentContext)); + formData = informationSystemService.createResourceInternal(resourceType, formData); + try { + //String currentCtx = SecretManagerProvider.instance.get().getContext(); + ResourceRegistryPublisher publisher = ResourceRegistryPublisherFactory.create(); + result = publisher.createResource(formData); + //result = publisher.create(formData); + }catch(Exception e) { + e.printStackTrace(); + log.error(e.getMessage()); + } + return result; + } + + //CRUD - 2 + @PostMapping("/updateresource") + String updateresource(@RequestParam String resourceType, @RequestBody String formData) throws Exception { String currentContext = SecretManagerProvider.instance.get().getContext(); String result = ""; informationSystemService.setUma(createUmaToken(currentContext)); formData = informationSystemService.createResourceInternal(resourceType, formData); try { - //String currentCtx = SecretManagerProvider.instance.get().getContext(); ResourceRegistryPublisher publisher = ResourceRegistryPublisherFactory.create(); - result = publisher.createResource(formData); - //result = publisher.create(formData); + result = publisher.updateResource(formData); }catch(Exception e) { - log.error("****************"); e.printStackTrace(); - log.error("****************"); log.error(e.getMessage()); } return result; diff --git a/src/main/webapp/app/facet-editor/facet-editor.component.html b/src/main/webapp/app/facet-editor/facet-editor.component.html index 9caba90..73ceb47 100644 --- a/src/main/webapp/app/facet-editor/facet-editor.component.html +++ b/src/main/webapp/app/facet-editor/facet-editor.component.html @@ -14,7 +14,6 @@

{{typeSpec.description}}

-
diff --git a/src/main/webapp/app/home/home.component.html b/src/main/webapp/app/home/home.component.html index 4d37280..98949be 100644 --- a/src/main/webapp/app/home/home.component.html +++ b/src/main/webapp/app/home/home.component.html @@ -64,6 +64,9 @@
+
+ +
diff --git a/src/main/webapp/app/services/i-virtual-machine.ts b/src/main/webapp/app/services/i-virtual-machine.ts new file mode 100644 index 0000000..e5162ff --- /dev/null +++ b/src/main/webapp/app/services/i-virtual-machine.ts @@ -0,0 +1,9 @@ +export interface IVirtualMachine { + type:string; + name: string; + id: string; + status: string; + lastMod: string; + avMemory: string; + hdSpace: string; +} diff --git a/src/main/webapp/app/services/resources-impl.service.ts b/src/main/webapp/app/services/resources-impl.service.ts index a615f13..02a9fb1 100644 --- a/src/main/webapp/app/services/resources-impl.service.ts +++ b/src/main/webapp/app/services/resources-impl.service.ts @@ -7,6 +7,7 @@ import { IHostingNode } from './i-hosting-node'; import { IEService } from './i-e-service'; import { ApplicationConfigService } from 'app/core/config/application-config.service'; import { IVirtualService } from './i-virtual-service'; +import { IVirtualMachine } from './i-virtual-machine'; @Injectable({ providedIn: 'root' @@ -36,6 +37,10 @@ export class ResourcesImplService { //console.debug("******GETTING HOSTING NODE*****"); return this.http.get(resourceUrl,{params:queryParams}); } + if(type==='VirtualMachine'){ + //console.debug("******GETTING HOSTING NODE*****"); + return this.http.get(resourceUrl,{params:queryParams}); + } if(type==='EService'){ return this.http.get(resourceUrl,{params:queryParams}); } diff --git a/src/main/webapp/app/shared/facet-model/BaseFacet.ts b/src/main/webapp/app/shared/facet-model/BaseFacet.ts new file mode 100644 index 0000000..11bc592 --- /dev/null +++ b/src/main/webapp/app/shared/facet-model/BaseFacet.ts @@ -0,0 +1,18 @@ +class BaseFacet { + uid:string; + facetName: string; + facetDescription: string; + facetMin: string; + facetMax: string; + customProperties: CustomProperty[]; + + constructor(){ + this.uid=''; + this.facetName=''; + this.facetMin=''; + this.facetMax=''; + this.facetDescription=''; + this.customProperties = []; + } + +} \ No newline at end of file diff --git a/src/main/webapp/app/shared/facet-model/CustomProperty.ts b/src/main/webapp/app/shared/facet-model/CustomProperty.ts new file mode 100644 index 0000000..e6d103f --- /dev/null +++ b/src/main/webapp/app/shared/facet-model/CustomProperty.ts @@ -0,0 +1,12 @@ +class CustomProperty { + name:string; + value:string; + type:string; + + constructor(){ + this.name=''; + this.value=''; + this.type=''; + } + +} \ No newline at end of file diff --git a/src/main/webapp/app/shared/facet-model/SoftwareFacet.ts b/src/main/webapp/app/shared/facet-model/SoftwareFacet.ts new file mode 100644 index 0000000..36c89eb --- /dev/null +++ b/src/main/webapp/app/shared/facet-model/SoftwareFacet.ts @@ -0,0 +1,22 @@ +class SoftwareFacet extends BaseFacet{ + name: string; + description: string; + relation: string; + optional: boolean; + group: string; + qualifier:string; + version:string; + + + constructor(){ + super(); + this.relation=''; + this.name=''; + this.group=''; + this.description=''; + this.qualifier=''; + this.version=''; + this.optional=false; + } + +} \ No newline at end of file diff --git a/src/main/webapp/app/table-screen-es/table-screen-es.component.spec.ts b/src/main/webapp/app/table-screen-es/table-screen-es.component.spec.ts deleted file mode 100644 index 22449c4..0000000 --- a/src/main/webapp/app/table-screen-es/table-screen-es.component.spec.ts +++ /dev/null @@ -1,23 +0,0 @@ -import { ComponentFixture, TestBed } from '@angular/core/testing'; - -import { TableScreenEsComponent } from './table-screen-es.component'; - -describe('TableScreenEsComponent', () => { - let component: TableScreenEsComponent; - let fixture: ComponentFixture; - - beforeEach(async () => { - await TestBed.configureTestingModule({ - declarations: [ TableScreenEsComponent ] - }) - .compileComponents(); - - fixture = TestBed.createComponent(TableScreenEsComponent); - component = fixture.componentInstance; - fixture.detectChanges(); - }); - - it('should create', () => { - expect(component).toBeTruthy(); - }); -}); diff --git a/src/main/webapp/app/table-screen-vs/table-screen-vs.component.scss b/src/main/webapp/app/table-screen-vs/table-screen-vs.component.scss deleted file mode 100644 index e69de29..0000000 diff --git a/src/main/webapp/app/table-screen-vs/table-screen-vs.module.ts b/src/main/webapp/app/table-screen-vs/table-screen-vs.module.ts index cf76145..5ee54ed 100644 --- a/src/main/webapp/app/table-screen-vs/table-screen-vs.module.ts +++ b/src/main/webapp/app/table-screen-vs/table-screen-vs.module.ts @@ -21,7 +21,6 @@ import { TableScreenVsComponent } from './table-screen-vs.component'; declarations:[TableScreenVsComponent], exports: [TableScreenVsComponent], - //NB: QUI VA DICHIARATO IL DIALOG DI DATAENTRY COME COMPONENT entryComponents: [ResourceAddComponent], bootstrap: [TableScreenVsComponent], }) diff --git a/src/main/webapp/app/table-screen/table-screen.component.ts b/src/main/webapp/app/table-screen/table-screen.component.ts index 39129b4..93dc9c3 100644 --- a/src/main/webapp/app/table-screen/table-screen.component.ts +++ b/src/main/webapp/app/table-screen/table-screen.component.ts @@ -165,6 +165,7 @@ export class TableScreenComponent implements OnInit, AfterViewInit, OnChanges { } reloadTable():void{ + alert(this.typeObject.name) this.myDataService.fetchResourceImpls(this.currentCtx.path,this.typeObject.name).subscribe(res => { this.dataFromService = res; this.dataSource.data = res;