3 * ============LICENSE_START=======================================================
4 * Copyright (C) 2022 Nordix Foundation.
5 * ================================================================================
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
10 * http://www.apache.org/licenses/LICENSE-2.0
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
18 * SPDX-License-Identifier: Apache-2.0
19 * ============LICENSE_END=========================================================
22 package org.openecomp.sdcrests.vsp.rest.services;
24 import static org.openecomp.sdcrests.vsp.rest.exception.OrchestrationTemplateCandidateUploadManagerExceptionSupplier.alreadyInStatusBeingUpdated;
25 import static org.openecomp.sdcrests.vsp.rest.exception.OrchestrationTemplateCandidateUploadManagerExceptionSupplier.couldNotCreateLock;
26 import static org.openecomp.sdcrests.vsp.rest.exception.OrchestrationTemplateCandidateUploadManagerExceptionSupplier.couldNotFindLock;
27 import static org.openecomp.sdcrests.vsp.rest.exception.OrchestrationTemplateCandidateUploadManagerExceptionSupplier.couldNotFindStatus;
28 import static org.openecomp.sdcrests.vsp.rest.exception.OrchestrationTemplateCandidateUploadManagerExceptionSupplier.couldNotUpdateLock;
29 import static org.openecomp.sdcrests.vsp.rest.exception.OrchestrationTemplateCandidateUploadManagerExceptionSupplier.couldNotUpdateStatus;
30 import static org.openecomp.sdcrests.vsp.rest.exception.OrchestrationTemplateCandidateUploadManagerExceptionSupplier.invalidCompletionStatus;
31 import static org.openecomp.sdcrests.vsp.rest.exception.OrchestrationTemplateCandidateUploadManagerExceptionSupplier.uploadAlreadyFinished;
32 import static org.openecomp.sdcrests.vsp.rest.exception.OrchestrationTemplateCandidateUploadManagerExceptionSupplier.vspUploadAlreadyInProgress;
34 import java.util.Date;
35 import java.util.List;
36 import java.util.Optional;
37 import java.util.UUID;
38 import java.util.concurrent.locks.Lock;
39 import java.util.concurrent.locks.ReentrantLock;
40 import org.openecomp.sdc.common.errors.CoreException;
41 import org.openecomp.sdc.vendorsoftwareproduct.VendorSoftwareProductManager;
42 import org.openecomp.sdc.vendorsoftwareproduct.VspManagerFactory;
43 import org.openecomp.sdc.vendorsoftwareproduct.dao.VspUploadStatusRecordDao;
44 import org.openecomp.sdc.vendorsoftwareproduct.dao.type.VspDetails;
45 import org.openecomp.sdc.vendorsoftwareproduct.dao.type.VspUploadStatus;
46 import org.openecomp.sdc.vendorsoftwareproduct.dao.type.VspUploadStatusRecord;
47 import org.openecomp.sdc.versioning.dao.types.Version;
48 import org.openecomp.sdcrests.vendorsoftwareproducts.types.VspUploadStatusDto;
49 import org.openecomp.sdcrests.vsp.rest.exception.OrchestrationTemplateCandidateUploadManagerExceptionSupplier;
50 import org.openecomp.sdcrests.vsp.rest.mapping.VspUploadStatusRecordMapper;
51 import org.slf4j.Logger;
52 import org.slf4j.LoggerFactory;
53 import org.springframework.beans.factory.annotation.Autowired;
54 import org.springframework.beans.factory.annotation.Qualifier;
55 import org.springframework.stereotype.Service;
58 * Manages the package upload process status.
61 public class OrchestrationTemplateCandidateUploadManagerImpl implements OrchestrationTemplateCandidateUploadManager {
63 private static final Logger LOGGER = LoggerFactory.getLogger(OrchestrationTemplateCandidateUploadManagerImpl.class);
65 private final VspUploadStatusRecordDao vspUploadStatusRecordDao;
66 private final VspUploadStatusRecordMapper vspUploadStatusRecordMapper;
67 private final VendorSoftwareProductManager vendorSoftwareProductManager;
68 private final Lock startUploadLock;
69 private final Lock updateStatusLock;
72 public OrchestrationTemplateCandidateUploadManagerImpl(
73 @Qualifier("vsp-upload-status-record-dao-impl") final VspUploadStatusRecordDao vspUploadStatusRecordDao) {
75 this.vspUploadStatusRecordDao = vspUploadStatusRecordDao;
76 this.vendorSoftwareProductManager = VspManagerFactory.getInstance().createInterface();
77 this.vspUploadStatusRecordMapper = new VspUploadStatusRecordMapper();
78 startUploadLock = new ReentrantLock();
79 updateStatusLock = new ReentrantLock();
83 OrchestrationTemplateCandidateUploadManagerImpl(final VspUploadStatusRecordDao vspUploadStatusRecordDao,
84 final VendorSoftwareProductManager vendorSoftwareProductManager) {
85 this.vspUploadStatusRecordDao = vspUploadStatusRecordDao;
86 this.vendorSoftwareProductManager = vendorSoftwareProductManager;
87 this.vspUploadStatusRecordMapper = new VspUploadStatusRecordMapper();
88 startUploadLock = new ReentrantLock();
89 updateStatusLock = new ReentrantLock();
93 public VspUploadStatusDto putUploadInProgress(final String vspId, final String vspVersionId, final String user) {
94 checkVspExists(vspId, vspVersionId);
95 LOGGER.debug("Start uploading for VSP id '{}', version '{}', triggered by user '{}'", vspId, vspVersionId, user);
97 final VspUploadStatusRecord vspUploadStatusRecord;
98 startUploadLock.lock();
100 final List<VspUploadStatusRecord> uploadInProgressList = vspUploadStatusRecordDao.findAllInProgress(vspId, vspVersionId);
101 if (!uploadInProgressList.isEmpty()) {
102 throw vspUploadAlreadyInProgress(vspId, vspVersionId).get();
105 vspUploadStatusRecord = new VspUploadStatusRecord();
106 vspUploadStatusRecord.setStatus(VspUploadStatus.UPLOADING);
107 vspUploadStatusRecord.setVspId(vspId);
108 vspUploadStatusRecord.setVspVersionId(vspVersionId);
109 vspUploadStatusRecord.setLockId(UUID.randomUUID());
110 vspUploadStatusRecord.setCreated(new Date());
112 vspUploadStatusRecordDao.create(vspUploadStatusRecord);
113 LOGGER.debug("Upload lock '{}' created for VSP id '{}', version '{}'", vspUploadStatusRecord.getLockId(), vspId, vspVersionId);
114 } catch (final CoreException e) {
116 } catch (final Exception e) {
117 throw couldNotCreateLock(vspId, vspVersionId, e).get();
119 startUploadLock.unlock();
122 return vspUploadStatusRecordMapper.applyMapping(vspUploadStatusRecord, VspUploadStatusDto.class);
126 public VspUploadStatusDto putUploadInValidation(final String vspId, final String vspVersionId, final String user) {
127 return updateToNotFinalStatus(vspId, vspVersionId, VspUploadStatus.VALIDATING, user);
131 public VspUploadStatusDto putUploadInProcessing(final String vspId, final String vspVersionId, final String user) {
132 return updateToNotFinalStatus(vspId, vspVersionId, VspUploadStatus.PROCESSING, user);
135 private VspUploadStatusDto updateToNotFinalStatus(final String vspId, final String vspVersionId, final VspUploadStatus status, final String user) {
136 LOGGER.debug("Updating upload status to '{}' for VSP id '{}', version '{}', triggered by user '{}'", status, vspId, vspVersionId, user);
137 if (status.isCompleteStatus()) {
138 throw invalidCompletionStatus(status).get();
140 updateStatusLock.lock();
142 final Optional<VspUploadStatusRecord> vspUploadStatusRecordOptional = vspUploadStatusRecordDao.findLatest(vspId, vspVersionId);
143 if (vspUploadStatusRecordOptional.isEmpty()) {
144 throw couldNotFindStatus(vspId, vspVersionId).get();
147 final VspUploadStatusRecord vspUploadStatusRecord = vspUploadStatusRecordOptional.get();
148 final VspUploadStatus currentStatus = vspUploadStatusRecord.getStatus();
149 if (currentStatus == status) {
150 throw alreadyInStatusBeingUpdated(vspId, vspVersionId, status).get();
152 return updateStatus(vspUploadStatusRecord, status);
154 updateStatusLock.unlock();
158 private VspUploadStatusDto updateStatus(final VspUploadStatusRecord vspUploadStatusRecord, final VspUploadStatus status) {
159 final VspUploadStatus currentStatus = vspUploadStatusRecord.getStatus();
160 vspUploadStatusRecord.setStatus(status);
161 vspUploadStatusRecord.setUpdated(new Date());
163 final String vspId = vspUploadStatusRecord.getVspId();
164 final String vspVersionId = vspUploadStatusRecord.getVspVersionId();
166 vspUploadStatusRecordDao.update(vspUploadStatusRecord);
167 LOGGER.debug("Upload lock '{}' status updated from '{}' to '{}' for VSP id '{}', version '{}'",
168 vspUploadStatusRecord.getLockId(), currentStatus, status, vspId, vspVersionId);
169 } catch (final Exception e) {
170 throw couldNotUpdateStatus(vspId, vspVersionId, status, e).get();
173 return vspUploadStatusRecordMapper.applyMapping(vspUploadStatusRecord, VspUploadStatusDto.class);
177 public VspUploadStatusDto putUploadAsFinished(final String vspId, final String vspVersionId, final UUID lockId, final VspUploadStatus completionStatus,
180 if (!completionStatus.isCompleteStatus()) {
181 throw OrchestrationTemplateCandidateUploadManagerExceptionSupplier.invalidCompleteStatus(completionStatus).get();
183 final Optional<VspUploadStatusRecord> vspUploadStatusOptional =
184 vspUploadStatusRecordDao.findByVspIdAndVersionIdAndLockId(vspId, vspVersionId, lockId);
185 if (vspUploadStatusOptional.isEmpty()) {
186 throw couldNotFindLock(lockId, vspId, vspVersionId).get();
188 final VspUploadStatusRecord vspUploadStatusRecord = vspUploadStatusOptional.get();
189 if (vspUploadStatusRecord.getIsComplete()) {
190 throw uploadAlreadyFinished(lockId, vspId, vspVersionId).get();
192 LOGGER.debug("Finishing the upload for VSP id '{}', version '{}', lock '{}', triggered by user '{}'",
193 vspUploadStatusRecord.getVspId(), vspUploadStatusRecord.getVspVersionId(), vspUploadStatusRecord.getLockId(), user);
194 vspUploadStatusRecord.setStatus(completionStatus);
195 vspUploadStatusRecord.setUpdated(new Date());
196 vspUploadStatusRecord.setIsComplete(true);
199 vspUploadStatusRecordDao.update(vspUploadStatusRecord);
200 LOGGER.debug("Upload complete for VSP '{}', version '{}', lock '{}'",
201 vspUploadStatusRecord.getLockId(), vspUploadStatusRecord.getVspId(), vspUploadStatusRecord.getVspVersionId());
202 } catch (final Exception e) {
203 throw couldNotUpdateLock(vspUploadStatusRecord.getLockId(), vspUploadStatusRecord.getVspId(), vspUploadStatusRecord.getVspVersionId(), e)
207 return vspUploadStatusRecordMapper.applyMapping(vspUploadStatusRecord, VspUploadStatusDto.class);
210 private void checkVspExists(final String vspId, final String vspVersionId) {
211 final VspDetails vspDetails = vendorSoftwareProductManager.getVsp(vspId, new Version(vspVersionId));
212 if (vspDetails == null) {
213 throw OrchestrationTemplateCandidateUploadManagerExceptionSupplier.vspNotFound(vspId, vspVersionId).get();
218 public Optional<VspUploadStatusDto> findLatestStatus(final String vspId, final String vspVersionId, final String user) {
219 checkVspExists(vspId, vspVersionId);
221 final Optional<VspUploadStatusRecord> vspUploadStatus = vspUploadStatusRecordDao.findLatest(vspId, vspVersionId);
222 if (vspUploadStatus.isEmpty()) {
223 return Optional.empty();
226 return Optional.of(vspUploadStatusRecordMapper.applyMapping(vspUploadStatus.get(), VspUploadStatusDto.class));