2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6 * ================================================================================
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.openecomp.sdc.vendorsoftwareproduct.utils;
23 import org.apache.commons.collections4.CollectionUtils;
24 import org.apache.commons.collections4.MapUtils;
25 import org.openecomp.core.enrichment.types.MonitoringUploadType;
26 import org.openecomp.core.utilities.file.FileContentHandler;
27 import org.openecomp.sdc.common.errors.ErrorCode;
28 import org.openecomp.sdc.common.errors.Messages;
29 import org.openecomp.sdc.common.utils.SdcCommon;
30 import org.openecomp.sdc.datatypes.error.ErrorLevel;
31 import org.openecomp.sdc.datatypes.error.ErrorMessage;
32 import org.openecomp.sdc.logging.api.Logger;
33 import org.openecomp.sdc.logging.api.LoggerFactory;
34 import org.openecomp.sdc.logging.context.impl.MdcDataErrorMessage;
35 import org.openecomp.sdc.logging.types.LoggerConstants;
36 import org.openecomp.sdc.logging.types.LoggerErrorDescription;
37 import org.openecomp.sdc.logging.types.LoggerServiceName;
38 import org.openecomp.sdc.vendorsoftwareproduct.dao.type.ComponentMonitoringUploadEntity;
39 import org.openecomp.sdc.vendorsoftwareproduct.types.OrchestrationTemplateActionResponse;
43 import java.util.ArrayList;
44 import java.util.Collection;
45 import java.util.HashMap;
46 import java.util.List;
49 public class VendorSoftwareProductUtils {
51 private static final String MANUAL = "Manual";
52 protected static Logger logger =
53 (Logger) LoggerFactory.getLogger(VendorSoftwareProductUtils.class);
56 * Add file names to upload file response.
58 * @param fileContentMap the file content map
59 * @param uploadFileResponse the upload file response
61 public static void addFileNamesToUploadFileResponse(FileContentHandler fileContentMap,
62 OrchestrationTemplateActionResponse uploadFileResponse) {
63 uploadFileResponse.setFileNames(new ArrayList<>());
64 for (String filename : fileContentMap.getFileList()) {
65 if (!new File(filename).isDirectory()) {
66 uploadFileResponse.addNewFileToList(filename);
69 uploadFileResponse.removeFileFromList(SdcCommon.MANIFEST_NAME);
73 * Validate raw zip data.
75 * @param uploadedFileData the uploaded file data
76 * @param errors the errors
78 public static void validateRawZipData(byte[] uploadedFileData,
79 Map<String, List<ErrorMessage>> errors) {
80 if (uploadedFileData.length == 0) {
81 MDC.put(LoggerConstants.ERROR_DESCRIPTION, LoggerErrorDescription.INVALID_ZIP);
82 ErrorMessage.ErrorMessageUtil.addMessage(SdcCommon.UPLOAD_FILE, errors).add(
83 new ErrorMessage(ErrorLevel.ERROR,
84 Messages.NO_ZIP_FILE_WAS_UPLOADED_OR_ZIP_NOT_EXIST.getErrorMessage()));
89 * Validate content zip data.
91 * @param contentMap the content map
92 * @param errors the errors
94 public static void validateContentZipData(FileContentHandler contentMap,
95 Map<String, List<ErrorMessage>> errors) {
96 MDC.put(LoggerConstants.ERROR_DESCRIPTION, LoggerErrorDescription.INVALID_ZIP);
97 if (contentMap.getFileList().size() == 0) {
98 ErrorMessage.ErrorMessageUtil.addMessage(SdcCommon.UPLOAD_FILE, errors)
99 .add(new ErrorMessage(ErrorLevel.ERROR, Messages.INVALID_ZIP_FILE.getErrorMessage()));
105 * Maps all artifacts by type.
107 * @param artifacts the artifacts
110 public static Map<MonitoringUploadType, String> mapArtifactsByType(
111 Collection<ComponentMonitoringUploadEntity> artifacts) {
112 Map<MonitoringUploadType, String> artifactTypeToFilename = new HashMap<>();
114 for (ComponentMonitoringUploadEntity entity : artifacts) {
115 artifactTypeToFilename.put(entity.getType(), entity.getArtifactName());
118 return artifactTypeToFilename;
122 private static boolean isTrapOrPoll(MonitoringUploadType type) {
123 return type.equals(MonitoringUploadType.SNMP_POLL) ||
124 type.equals(MonitoringUploadType.SNMP_TRAP);
129 * Sets errors into logger.
131 * @param errors the errors
132 * @param serviceName the service name
133 * @param targetServiceName the target service name
135 public static void setErrorsIntoLogger(Map<String, List<ErrorMessage>> errors,
136 LoggerServiceName serviceName, String targetServiceName) {
137 MdcDataErrorMessage mdcDataErrorMessage =
138 new MdcDataErrorMessage(targetServiceName, LoggerConstants.TARGET_ENTITY_DB,
139 ErrorLevel.ERROR.name(), null, null);
140 mdcDataErrorMessage.setMdcValues();
142 if (MapUtils.isEmpty(errors)) {
146 for (Map.Entry<String, List<ErrorMessage>> listEntry : errors.entrySet()) {
147 List<ErrorMessage> errorList = listEntry.getValue();
148 for (ErrorMessage message : errorList) {
149 logger.error(message.getMessage());
155 * Sets errors into logger.
157 * @param errors the errors
158 * @param serviceName the service name
159 * @param targetServiceName the target service name
161 public static void setErrorsIntoLogger(Collection<ErrorCode> errors,
162 LoggerServiceName serviceName, String targetServiceName) {
163 MdcDataErrorMessage mdcDataErrorMessage =
164 new MdcDataErrorMessage(targetServiceName, LoggerConstants.TARGET_ENTITY_DB,
165 ErrorLevel.ERROR.name(), null, null);
166 mdcDataErrorMessage.setMdcValues();
168 if (CollectionUtils.isEmpty(errors)) {
172 for (ErrorCode error : errors) {
173 logger.error(error.message());
177 /*public static boolean isManual(String vspId, Version version, VendorSoftwareProductInfoDao
179 String onboardingMethod = vspInfoDao.get(new VspDetails(vspId, version)).getOnboardingMethod();
180 if (MANUAL.equals(onboardingMethod)) {