2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 # Copyright (c) 2020, CMCC Technologies Co., Ltd.
7 # Licensed under the Apache License, Version 2.0 (the "License")
8 # you may not use this file except in compliance with the License.
9 # You may obtain a copy of the License at
11 # http://www.apache.org/licenses/LICENSE-2.0
13 # Unless required by applicable law or agreed to in writing, software
14 # distributed under the License is distributed on an "AS IS" BASIS,
15 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 # See the License for the specific language governing permissions and
17 # limitations under the License.
18 * ============LICENSE_END=========================================================
21 package org.onap.so.adapters.nssmf.manager.impl;
23 import org.apache.http.Header;
24 import org.apache.http.message.BasicHeader;
25 import org.onap.aai.domain.yang.ServiceInstance;
26 import org.onap.so.adapters.nssmf.entity.NssmfInfo;
27 import org.onap.so.adapters.nssmf.entity.RestResponse;
28 import org.onap.so.adapters.nssmf.enums.ActionType;
29 import org.onap.so.adapters.nssmf.enums.JobStatus;
30 import org.onap.so.adapters.nssmf.exceptions.ApplicationException;
31 import org.onap.so.adapters.nssmf.util.NssmfAdapterUtil;
32 import org.onap.so.beans.nsmf.*;
33 import org.onap.so.db.request.beans.ResourceOperationStatus;
34 import static java.lang.String.valueOf;
35 import static org.onap.so.adapters.nssmf.enums.JobStatus.*;
36 import static org.onap.so.adapters.nssmf.util.NssmfAdapterUtil.StatusDesc.*;
37 import static org.onap.so.adapters.nssmf.util.NssmfAdapterUtil.marshal;
38 import static org.onap.so.adapters.nssmf.util.NssmfAdapterUtil.unMarshal;
40 public abstract class ExternalNssmfManager extends BaseNssmfManager {
43 protected String wrapAllocateReqBody(NssmfAdapterNBIRequest nbiRequest) throws ApplicationException {
44 return doWrapExtAllocateReqBody(nbiRequest);
47 protected abstract String doWrapExtAllocateReqBody(NssmfAdapterNBIRequest nbiRequest) throws ApplicationException;
50 protected String wrapModifyReqBody(NssmfAdapterNBIRequest nbiRequest) throws ApplicationException {
51 return doWrapModifyReqBody(nbiRequest);
54 protected abstract String doWrapModifyReqBody(NssmfAdapterNBIRequest nbiRequest) throws ApplicationException;
57 protected String wrapDeAllocateReqBody(DeAllocateNssi deAllocateNssi) throws ApplicationException {
58 return doWrapDeAllocateReqBody(deAllocateNssi);
61 protected abstract String doWrapDeAllocateReqBody(DeAllocateNssi deAllocateNssi) throws ApplicationException;
64 protected void afterQueryJobStatus(ResourceOperationStatus status) {
65 if (Integer.parseInt(status.getProgress()) == 100) {
67 ActionType jobOperType = ActionType.valueOf(status.getOperType());
69 if (ActionType.ALLOCATE.equals(jobOperType)) {
70 ServiceInstance nssiInstance = restUtil.getServiceInstance(serviceInfo);
71 if (nssiInstance == null) {
72 nssiInstance = new ServiceInstance();
75 nssiInstance.setServiceInstanceId(serviceInfo.getNssiId());
76 nssiInstance.setServiceInstanceName(serviceInfo.getNssiName());
77 nssiInstance.setServiceType(serviceInfo.getSST());
79 nssiInstance.setOrchestrationStatus(initStatus);
80 nssiInstance.setModelInvariantId(serviceInfo.getServiceInvariantUuid());
81 nssiInstance.setModelVersionId(serviceInfo.getServiceUuid());
82 nssiInstance.setServiceInstanceLocationId(serviceInfo.getPLMNIdList());
83 nssiInstance.setEnvironmentContext(esrInfo.getNetworkType().getNetworkType());
84 nssiInstance.setServiceRole("nssi");
86 restUtil.createServiceInstance(nssiInstance, serviceInfo);
87 } else if (ActionType.DEALLOCATE.equals(jobOperType)) {
88 restUtil.deleteServiceInstance(serviceInfo);
94 protected String wrapActDeActReqBody(ActDeActNssi actDeActNssi) throws ApplicationException {
95 return marshal(actDeActNssi);
99 protected RestResponse doQueryJobStatus(ResourceOperationStatus status) throws ApplicationException {
100 return doResponseStatus(status);
103 private RestResponse doResponseStatus(ResourceOperationStatus status) throws ApplicationException {
104 RestResponse restResponse = sendRequest(null);
105 JobStatusResponse jobStatusResponse = unMarshal(restResponse.getResponseContent(), JobStatusResponse.class);
107 ResponseDescriptor rspDesc = jobStatusResponse.getResponseDescriptor();
108 rspDesc.setNssiId(status.getResourceInstanceID());
110 jobStatusResponse.setResponseDescriptor(rspDesc);
111 restResponse.setResponseContent(marshal(jobStatusResponse));
112 updateRequestDbJobStatus(rspDesc, status, restResponse);
117 protected String wrapReqBody(Object object) throws ApplicationException {
118 return marshal(object);
122 protected RestResponse sendRequest(String content) throws ApplicationException {
123 return sendExternalRequest(content);
127 protected String getApiVersion() {
133 protected RestResponse sendExternalRequest(String content) throws ApplicationException {
134 NssmfInfo nssmfInfo = restUtil.getNssmfHost(esrInfo);
135 Header header = new BasicHeader("X-Auth-Token", restUtil.getToken(nssmfInfo));
136 String nssmfUrl = nssmfInfo.getUrl() + this.nssmfUrl;
137 return restUtil.send(nssmfUrl, this.httpMethod, content, header);
140 protected void updateRequestDbJobStatus(ResponseDescriptor rspDesc, ResourceOperationStatus status,
141 RestResponse rsp) throws ApplicationException {
143 switch (fromString(rspDesc.getStatus())) {
145 updateDbStatus(status, rsp.getStatus(), STARTED, QUERY_JOB_STATUS_SUCCESS);
148 updateDbStatus(status, rsp.getStatus(), PROCESSING, QUERY_JOB_STATUS_SUCCESS);
151 if (rspDesc.getProgress() == 100) {
152 updateDbStatus(status, rsp.getStatus(), FINISHED, QUERY_JOB_STATUS_SUCCESS);
156 updateDbStatus(status, rsp.getStatus(), ERROR, QUERY_JOB_STATUS_FAILED);
157 throw new ApplicationException(500, QUERY_JOB_STATUS_FAILED);
161 protected void updateDbStatus(ResourceOperationStatus status, int rspStatus, JobStatus jobStatus,
162 String description) {
163 status.setErrorCode(valueOf(rspStatus));
164 status.setStatus(jobStatus.toString());
165 status.setStatusDescription(description);
166 repository.save(status);
170 protected <T> RestResponse doQuerySubnetCapability(T req) throws ApplicationException {
171 RestResponse response = new RestResponse();
172 response.setStatus(200);
173 response.setResponseContent(null);
178 * after request, if response code is 2XX, continue handle, else return
181 protected void afterRequest() throws ApplicationException {
182 if (valueOf(restResponse.getStatus()).startsWith("2")) {
188 protected void doAfterRequest() throws ApplicationException {
190 NssiResponse response = unMarshal(restResponse.getResponseContent(), NssiResponse.class);
191 ResourceOperationStatus status =
192 new ResourceOperationStatus(serviceInfo.getNsiId(), response.getJobId(), serviceInfo.getServiceUuid());
193 status.setResourceInstanceID(response.getNssiId());
195 updateDbStatus(status, restResponse.getStatus(), STARTED, NssmfAdapterUtil.getStatusDesc(actionType));