Added presentation of owner of EiJob
Change-Id: I70ed2af455af7a5fa82f19c47b6cae7d18530da1
Issue-ID: NONRTRIC-294
Signed-off-by: PatrikBuhr <patrik.buhr@est.tech>
diff --git a/webapp-backend/src/main/java/org/oransc/portal/nonrtric/controlpanel/model/JobInfo.java b/webapp-backend/src/main/java/org/oransc/portal/nonrtric/controlpanel/model/JobInfo.java
index e8ec292..78bbd87 100644
--- a/webapp-backend/src/main/java/org/oransc/portal/nonrtric/controlpanel/model/JobInfo.java
+++ b/webapp-backend/src/main/java/org/oransc/portal/nonrtric/controlpanel/model/JobInfo.java
@@ -54,4 +54,9 @@
@JsonProperty("target_uri")
public String targetUri;
+ @ApiModelProperty(value = "The owner of the job")
+ @SerializedName("owner")
+ @JsonProperty("owner")
+ public String owner;
+
}
diff --git a/webapp-backend/src/test/java/org/oransc/portal/nonrtric/controlpanel/RestApiTest.java b/webapp-backend/src/test/java/org/oransc/portal/nonrtric/controlpanel/RestApiTest.java
index 4243c34..c4acad2 100644
--- a/webapp-backend/src/test/java/org/oransc/portal/nonrtric/controlpanel/RestApiTest.java
+++ b/webapp-backend/src/test/java/org/oransc/portal/nonrtric/controlpanel/RestApiTest.java
@@ -91,6 +91,7 @@
.typeId("type1") //
.jobData(getStringFromFile("job-1.json")) //
.targetUri("http://example.com/") //
+ .owner("owner") //
.build();
assertThat(jobs).hasSize(1) //
.contains(gson.toJsonTree(wantedJobInfo));
diff --git a/webapp-backend/src/test/java/org/oransc/portal/nonrtric/controlpanel/mock/EiJob.java b/webapp-backend/src/test/java/org/oransc/portal/nonrtric/controlpanel/mock/EiJob.java
deleted file mode 100644
index 56d3fc8..0000000
--- a/webapp-backend/src/test/java/org/oransc/portal/nonrtric/controlpanel/mock/EiJob.java
+++ /dev/null
@@ -1,42 +0,0 @@
-/*-
- * ========================LICENSE_START=================================
- * O-RAN-SC
- * %%
- * Copyright (C) 2019 Nordix Foundation
- * Modifications Copyright (C) 2020 Nordix Foundation
- * %%
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- * ========================LICENSE_END===================================
- */
-package org.oransc.portal.nonrtric.controlpanel.mock;
-
-import org.immutables.gson.Gson;
-import org.immutables.value.Value;
-
-@Value.Immutable
-@Gson.TypeAdapters
-public interface EiJob {
-
- public String ei_job_identity();
-
- public String target_uri();
-
- public Object ei_job_data();
-
- public String ei_type_identity();
-
- public String owner();
-
- public String status();
-
-}
diff --git a/webapp-backend/src/test/java/org/oransc/portal/nonrtric/controlpanel/mock/EiJobs.java b/webapp-backend/src/test/java/org/oransc/portal/nonrtric/controlpanel/mock/EiJobs.java
index 0a486ec..ce831d3 100644
--- a/webapp-backend/src/test/java/org/oransc/portal/nonrtric/controlpanel/mock/EiJobs.java
+++ b/webapp-backend/src/test/java/org/oransc/portal/nonrtric/controlpanel/mock/EiJobs.java
@@ -22,7 +22,9 @@
import java.util.ArrayList;
-public class EiJobs extends ArrayList<EiJob> {
+import org.oransc.portal.nonrtric.controlpanel.model.JobInfo;
+
+public class EiJobs extends ArrayList<JobInfo> {
private static final long serialVersionUID = -928428052502491021L;
diff --git a/webapp-backend/src/test/java/org/oransc/portal/nonrtric/controlpanel/mock/EnrichmentControllerMockConfiguration.java b/webapp-backend/src/test/java/org/oransc/portal/nonrtric/controlpanel/mock/EnrichmentControllerMockConfiguration.java
index 43be49f..c0fb4f1 100644
--- a/webapp-backend/src/test/java/org/oransc/portal/nonrtric/controlpanel/mock/EnrichmentControllerMockConfiguration.java
+++ b/webapp-backend/src/test/java/org/oransc/portal/nonrtric/controlpanel/mock/EnrichmentControllerMockConfiguration.java
@@ -33,10 +33,10 @@
import java.util.HashMap;
import java.util.List;
import java.util.Map;
-import java.util.Optional;
import java.util.stream.Collectors;
import org.oransc.portal.nonrtric.controlpanel.eiproducerapi.EiProducerApi;
+import org.oransc.portal.nonrtric.controlpanel.model.JobInfo;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.test.context.TestConfiguration;
@@ -88,8 +88,8 @@
@Override
public ResponseEntity<String> getEiJobsForOneEiProducer(String eiProducerId) {
EiJobs result = new EiJobs();
- List<EiJob> inst = database.getEiJobsForOneEiProducer(Optional.of(eiProducerId));
- result.addAll(inst);
+
+ result.addAll(database.getAllEiJobs());
return new ResponseEntity<>(gson.toJson(result), HttpStatus.OK);
}
@@ -122,7 +122,7 @@
// Create EiJob instance
schema = getStringFromFile("job-1.json");
- putEiJobInstance("type1", "job1", schema, "prod-1", "http://example.com/");
+ putEiJobInstance("type1", "job1", schema, "owner", "http://example.com/");
}
private String getStringFromFile(String path) {
@@ -141,13 +141,12 @@
}
void putEiJobInstance(String typeId, String instanceId, Object instanceData, String owner, String targetUrl) {
- EiJob i = ImmutableEiJob.builder() //
- .ei_job_data(instanceData) //
- .ei_job_identity(instanceId) //
+ JobInfo i = JobInfo.builder() //
+ .jobData(instanceData) //
+ .id(instanceId) //
.owner(owner) //
- .ei_type_identity(typeId) //
- .target_uri(targetUrl) //
- .status("ENABLED") //
+ .typeId(typeId) //
+ .targetUri(targetUrl) //
.build(); //
eiJobs.put(instanceId, i);
}
@@ -196,26 +195,12 @@
return eiProducers.values();
}
- public Collection<EiJob> getAllEiJobs() {
- return eiJobs.values();
- }
+ public List<JobInfo> getAllEiJobs() {
+ return new ArrayList<>(eiJobs.values());
- public List<EiJob> getEiJobsForOneEiProducer(Optional<String> eiProducerId) {
- List<EiJob> result = new ArrayList<>();
- for (EiJob i : eiJobs.values()) {
- if (eiProducerId.isPresent()) {
- if (i.owner().equals(eiProducerId.get())) {
- result.add(i);
- }
-
- } else {
- result.add(i);
- }
- }
- return result;
}
private Map<String, EiProducer> eiProducers = new HashMap<>();
- private Map<String, EiJob> eiJobs = new HashMap<>();
+ private Map<String, JobInfo> eiJobs = new HashMap<>();
}
}
diff --git a/webapp-frontend/src/app/ei-coordinator/ei-coordinator.component.html b/webapp-frontend/src/app/ei-coordinator/ei-coordinator.component.html
index ada0384..e90f945 100644
--- a/webapp-frontend/src/app/ei-coordinator/ei-coordinator.component.html
+++ b/webapp-frontend/src/app/ei-coordinator/ei-coordinator.component.html
@@ -63,10 +63,14 @@
<th mat-header-cell *matHeaderCellDef> Type ID </th>
<td mat-cell *matCellDef="let eiJob"> {{this.getEITypeId(eiJob)}} </td>
</ng-container>
+ <ng-container matColumnDef="owner">
+ <th mat-header-cell *matHeaderCellDef> Owner </th>
+ <td mat-cell *matCellDef="let eiJob"> {{eiJob.owner}} </td>
+ </ng-container>
<ng-container matColumnDef="targetUri">
<th mat-header-cell *matHeaderCellDef> Target URI </th>
<td mat-cell *matCellDef="let eiJob"> {{this.getTargetUri(eiJob)}} </td>
</ng-container>
- <tr mat-header-row *matHeaderRowDef="['id', 'typeId', 'targetUri']"></tr>
- <tr mat-row *matRowDef="let row; columns: ['id', 'typeId', 'targetUri'];"></tr>
+ <tr mat-header-row *matHeaderRowDef="['id', 'typeId', 'owner', 'targetUri']"></tr>
+ <tr mat-row *matRowDef="let row; columns: ['id', 'typeId', 'owner', 'targetUri'];"></tr>
</table>
\ No newline at end of file
diff --git a/webapp-frontend/src/app/ei-coordinator/ei-coordinator.component.ts b/webapp-frontend/src/app/ei-coordinator/ei-coordinator.component.ts
index 3360577..15c4738 100644
--- a/webapp-frontend/src/app/ei-coordinator/ei-coordinator.component.ts
+++ b/webapp-frontend/src/app/ei-coordinator/ei-coordinator.component.ts
@@ -97,14 +97,14 @@
}
getEITypeId(eiJob: EIJob): string {
- if (eiJob.ei_type_identity){
+ if (eiJob.ei_type_identity) {
return eiJob.ei_type_identity;
}
return '< No type >';
}
getTargetUri(eiJob: EIJob): string {
- if (eiJob.target_uri){
+ if (eiJob.target_uri) {
return eiJob.target_uri;
}
return '< No target URI >';
@@ -119,21 +119,21 @@
}
getEIProducerId(eiProducer: EIProducer): string {
- if (eiProducer.ei_producer_id){
+ if (eiProducer.ei_producer_id) {
return eiProducer.ei_producer_id;
}
return '< No id>';
}
getEIProducerTypes(eiProducer: EIProducer): string[] {
- if (eiProducer.ei_producer_types){
+ if (eiProducer.ei_producer_types) {
return eiProducer.ei_producer_types;
}
return ['< No types >'];
}
getEIProducerStatus(eiProducer: EIProducer): string {
- if (eiProducer.status){
+ if (eiProducer.status) {
return eiProducer.status;
}
return '< No status >';
diff --git a/webapp-frontend/src/app/interfaces/ei.jobs.ts b/webapp-frontend/src/app/interfaces/ei.jobs.ts
index e7d034a..4ead13f 100644
--- a/webapp-frontend/src/app/interfaces/ei.jobs.ts
+++ b/webapp-frontend/src/app/interfaces/ei.jobs.ts
@@ -21,27 +21,28 @@
// Models of data used by the EI Coordinator
export interface EIJobBis {
- eiTypeId: string;
- jobResultUri: string;
- jobOwner: string;
- jobStatusNotificationUri: string;
- jobDefinition: any;
- }
+ eiTypeId: string;
+ jobResultUri: string;
+ jobOwner: string;
+ jobStatusNotificationUri: string;
+ jobDefinition: any;
+}
- export interface EIJob {
- ei_job_identity: string;
- ei_job_data: any;
- ei_type_identity: string;
- target_uri: string;
- }
+export interface EIJob {
+ ei_job_identity: string;
+ ei_job_data: any;
+ ei_type_identity: string;
+ target_uri: string;
+ owner: string;
+}
- export interface EIType {
- id: string;
- description: string;
- }
+export interface EIType {
+ id: string;
+ description: string;
+}
- export interface EIProducer {
- ei_producer_id: string;
- ei_producer_types: string[];
- status: string;
- }
\ No newline at end of file
+export interface EIProducer {
+ ei_producer_id: string;
+ ei_producer_types: string[];
+ status: string;
+}
\ No newline at end of file