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.JobStatus;
29 import org.onap.so.adapters.nssmf.exceptions.ApplicationException;
30 import org.onap.so.adapters.nssmf.util.NssmfAdapterUtil;
31 import org.onap.so.beans.nsmf.*;
32 import org.onap.so.db.request.beans.ResourceOperationStatus;
33 import org.slf4j.Logger;
34 import org.slf4j.LoggerFactory;
35 import static java.lang.String.valueOf;
36 import static org.onap.so.adapters.nssmf.enums.JobStatus.*;
37 import static org.onap.so.adapters.nssmf.util.NssmfAdapterUtil.StatusDesc.*;
38 import static org.onap.so.adapters.nssmf.util.NssmfAdapterUtil.marshal;
39 import static org.onap.so.adapters.nssmf.util.NssmfAdapterUtil.unMarshal;
41 public abstract class ExternalNssmfManager extends BaseNssmfManager {
43 private static final Logger logger = LoggerFactory.getLogger(ExternalNssmfManager.class);
46 protected String wrapAllocateReqBody(NssmfAdapterNBIRequest nbiRequest) throws ApplicationException {
47 return doWrapExtAllocateReqBody(nbiRequest);
50 protected abstract String doWrapExtAllocateReqBody(NssmfAdapterNBIRequest nbiRequest) throws ApplicationException;
53 protected String wrapModifyReqBody(NssmfAdapterNBIRequest nbiRequest) throws ApplicationException {
54 return doWrapModifyReqBody(nbiRequest);
57 protected abstract String doWrapModifyReqBody(NssmfAdapterNBIRequest nbiRequest) throws ApplicationException;
60 protected String wrapDeAllocateReqBody(DeAllocateNssi deAllocateNssi) throws ApplicationException {
61 return doWrapDeAllocateReqBody(deAllocateNssi);
64 protected abstract String doWrapDeAllocateReqBody(DeAllocateNssi deAllocateNssi) throws ApplicationException;
67 protected void afterQueryJobStatus(ResourceOperationStatus status) {
68 if (Integer.parseInt(status.getProgress()) == 100) {
70 ServiceInstance nssiInstance = new ServiceInstance();
71 nssiInstance.setServiceInstanceId(serviceInfo.getNssiId());
72 nssiInstance.setServiceInstanceName(serviceInfo.getNssiName());
73 nssiInstance.setServiceType(serviceInfo.getSST());
75 nssiInstance.setOrchestrationStatus(initStatus);
76 nssiInstance.setModelInvariantId(serviceInfo.getServiceInvariantUuid());
77 nssiInstance.setModelVersionId(serviceInfo.getServiceUuid());
78 nssiInstance.setServiceInstanceLocationId(serviceInfo.getPLMNIdList());
79 nssiInstance.setEnvironmentContext(esrInfo.getNetworkType().getNetworkType());
80 nssiInstance.setServiceRole("nssi");
82 restUtil.createServiceInstance(nssiInstance, serviceInfo);
89 protected String wrapActDeActReqBody(ActDeActNssi actDeActNssi) throws ApplicationException {
90 return marshal(actDeActNssi);
93 protected RestResponse doQueryJobStatus(ResourceOperationStatus status) throws ApplicationException {
94 return doResponseStatus(status);
97 private RestResponse doResponseStatus(ResourceOperationStatus status) throws ApplicationException {
98 RestResponse restResponse = sendRequest(null);
99 ResponseDescriptor rspDesc =
100 unMarshal(restResponse.getResponseContent(), JobStatusResponse.class).getResponseDescriptor();
101 updateRequestDbJobStatus(rspDesc, status, restResponse);
106 protected String wrapReqBody(Object object) throws ApplicationException {
107 return marshal(object);
111 protected RestResponse sendRequest(String content) throws ApplicationException {
112 return sendExternalRequest(content);
115 protected void createStatus(JobStatus jobStatus) throws ApplicationException {
116 if (valueOf(restResponse.getStatus()).startsWith("2")) {
117 logger.info("save segment and operaton info -> begin");
118 NssiResponse response = unMarshal(restResponse.getResponseContent(), NssiResponse.class);
119 ResourceOperationStatus status = new ResourceOperationStatus(serviceInfo.getNsiId(), response.getJobId(),
120 serviceInfo.getServiceUuid());
121 status.setResourceInstanceID(response.getNssiId());
123 updateDbStatus(status, restResponse.getStatus(), jobStatus, NssmfAdapterUtil.getStatusDesc(actionType));
124 logger.info("save segment and operaton info -> end");
129 protected String getApiVersion() {
135 protected RestResponse sendExternalRequest(String content) throws ApplicationException {
136 NssmfInfo nssmfInfo = restUtil.getNssmfHost(esrInfo);
137 Header header = new BasicHeader("X-Auth-Token", restUtil.getToken(nssmfInfo));
138 String nssmfUrl = nssmfInfo.getUrl() + this.nssmfUrl;
139 return restUtil.send(nssmfUrl, this.httpMethod, content, header);
142 private void updateRequestDbJobStatus(ResponseDescriptor rspDesc, ResourceOperationStatus status, RestResponse rsp)
143 throws ApplicationException {
145 switch (fromString(rspDesc.getStatus())) {
147 updateDbStatus(status, rsp.getStatus(), STARTED, QUERY_JOB_STATUS_SUCCESS);
150 updateDbStatus(status, rsp.getStatus(), PROCESSING, QUERY_JOB_STATUS_SUCCESS);
153 if (rspDesc.getProgress() == 100) {
154 updateDbStatus(status, rsp.getStatus(), FINISHED, QUERY_JOB_STATUS_SUCCESS);
158 updateDbStatus(status, rsp.getStatus(), ERROR, QUERY_JOB_STATUS_FAILED);
159 throw new ApplicationException(500, QUERY_JOB_STATUS_FAILED);
163 protected void updateDbStatus(ResourceOperationStatus status, int rspStatus, JobStatus jobStatus,
164 String description) {
165 status.setErrorCode(valueOf(rspStatus));
166 status.setStatus(jobStatus.toString());
167 status.setStatusDescription(description);
168 logger.info("Updating DB status");
169 repository.save(status);
170 logger.info("Updating successful");
174 protected RestResponse doQuerySubnetCapability(String req) throws ApplicationException {
175 RestResponse response = new RestResponse();
176 response.setStatus(200);
177 response.setResponseContent(null);
182 * after request, if response code is 2XX, continue handle, else return
185 protected void afterRequest() throws ApplicationException {
186 if (valueOf(restResponse.getStatus()).startsWith("2")) {
192 protected void doAfterRequest() throws ApplicationException {
194 NssiResponse response = unMarshal(restResponse.getResponseContent(), NssiResponse.class);
195 ResourceOperationStatus status =
196 new ResourceOperationStatus(serviceInfo.getNsiId(), response.getJobId(), serviceInfo.getServiceUuid());
197 status.setResourceInstanceID(response.getNssiId());
199 updateDbStatus(status, restResponse.getStatus(), STARTED, NssmfAdapterUtil.getStatusDesc(actionType));