2 * Copyright © 2017-2018 AT&T Intellectual Property.
3 * Modifications Copyright © 2019 Bell Canada.
4 * Modifications Copyright © 2019 IBM.
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.
19 package org.onap.ccsdk.cds.blueprintsprocessor.db.primary.service
21 import org.onap.ccsdk.cds.blueprintsprocessor.db.primary.domain.BlueprintModel
22 import org.onap.ccsdk.cds.blueprintsprocessor.db.primary.domain.BlueprintModelContent
23 import org.onap.ccsdk.cds.blueprintsprocessor.db.primary.repository.BlueprintModelRepository
24 import org.onap.ccsdk.cds.controllerblueprints.core.*
25 import org.onap.ccsdk.cds.controllerblueprints.core.common.ApplicationConstants
26 import org.onap.ccsdk.cds.controllerblueprints.core.config.BluePrintLoadConfiguration
27 import org.onap.ccsdk.cds.controllerblueprints.core.data.ErrorCode
28 import org.onap.ccsdk.cds.controllerblueprints.core.interfaces.BluePrintValidatorService
29 import org.onap.ccsdk.cds.controllerblueprints.core.scripts.BluePrintCompileCache
30 import org.onap.ccsdk.cds.controllerblueprints.core.utils.BluePrintFileUtils
31 import org.slf4j.LoggerFactory
32 import org.springframework.dao.DataIntegrityViolationException
33 import org.springframework.stereotype.Service
35 import java.nio.file.Files
36 import java.nio.file.Path
39 //TODO("Duplicate : Merge BlueprintProcessorCatalogServiceImpl and ControllerBlueprintCatalogServiceImpl")
41 * Similar implementation in [org.onap.ccsdk.cds.blueprintsprocessor.db.BlueprintProcessorCatalogServiceImpl]
43 @Service("controllerBlueprintsCatalogService")
44 class ControllerBlueprintCatalogServiceImpl(bluePrintDesignTimeValidatorService: BluePrintValidatorService,
45 private val bluePrintLoadConfiguration: BluePrintLoadConfiguration,
46 private val blueprintModelRepository: BlueprintModelRepository)
47 : BlueprintCatalogServiceImpl(bluePrintLoadConfiguration, bluePrintDesignTimeValidatorService) {
50 private val log = LoggerFactory.getLogger(ControllerBlueprintCatalogServiceImpl::class.toString())
53 log.info("BlueprintProcessorCatalogServiceImpl initialized")
56 override suspend fun delete(name: String, version: String) {
57 // Cleaning Deployed Blueprint
58 deleteDir(bluePrintLoadConfiguration.blueprintDeployPath, name, version)
60 blueprintModelRepository.deleteByArtifactNameAndArtifactVersion(name, version)
63 override suspend fun get(name: String, version: String, extract: Boolean): Path? {
64 val path = if (extract) {
65 normalizedPath(bluePrintLoadConfiguration.blueprintDeployPath, name, version)
67 normalizedPath(bluePrintLoadConfiguration.blueprintArchivePath, UUID.randomUUID().toString(), "cba.zip")
69 blueprintModelRepository.findByArtifactNameAndArtifactVersion(name, version)?.also {
70 it.blueprintModelContent.run {
71 path.toFile().writeBytes(this!!.content!!).let {
79 override suspend fun save(metadata: MutableMap<String, String>, archiveFile: File) {
81 val artifactName = metadata[BluePrintConstants.METADATA_TEMPLATE_NAME]
82 val artifactVersion = metadata[BluePrintConstants.METADATA_TEMPLATE_VERSION]
84 check(archiveFile.isFile && !archiveFile.isDirectory) {
85 throw BluePrintException("Not a valid Archive file(${archiveFile.absolutePath})")
88 // cleanup up deploy folder for the Blueprint
89 val blueprintDeploy = normalizedPathName(bluePrintLoadConfiguration.blueprintDeployPath,
90 artifactName, artifactVersion)
91 val cacheKey = BluePrintFileUtils.compileCacheKey(blueprintDeploy)
92 BluePrintCompileCache.cleanClassLoader(cacheKey)
94 blueprintModelRepository.findByArtifactNameAndArtifactVersion(artifactName!!, artifactVersion!!)?.let {
95 log.info("Overwriting blueprint model :$artifactName::$artifactVersion")
96 blueprintModelRepository.deleteByArtifactNameAndArtifactVersion(artifactName, artifactVersion)
99 val blueprintModel = BlueprintModel()
100 blueprintModel.id = metadata[BluePrintConstants.PROPERTY_BLUEPRINT_PROCESS_ID]
101 blueprintModel.artifactType = ApplicationConstants.ASDC_ARTIFACT_TYPE_SDNC_MODEL
102 blueprintModel.published = metadata[BluePrintConstants.PROPERTY_BLUEPRINT_VALID]
103 ?: BluePrintConstants.FLAG_N
104 blueprintModel.artifactName = artifactName
105 blueprintModel.artifactVersion = artifactVersion
106 blueprintModel.updatedBy = metadata[BluePrintConstants.METADATA_TEMPLATE_AUTHOR]!!
107 blueprintModel.tags = metadata[BluePrintConstants.METADATA_TEMPLATE_TAGS]!!
108 blueprintModel.artifactDescription = "Controller Blueprint for $artifactName:$artifactVersion"
110 val blueprintModelContent = BlueprintModelContent()
111 blueprintModelContent.id = metadata[BluePrintConstants.PROPERTY_BLUEPRINT_PROCESS_ID]
112 blueprintModelContent.contentType = "CBA_ZIP"
113 blueprintModelContent.name = "$artifactName:$artifactVersion"
114 blueprintModelContent.description = "$artifactName:$artifactVersion CBA Zip Content"
115 blueprintModelContent.content = Files.readAllBytes(archiveFile.toPath())
116 blueprintModelContent.blueprintModel = blueprintModel
117 // Set the Blueprint Model Content into blueprintModel
118 blueprintModel.blueprintModelContent = blueprintModelContent
121 blueprintModelRepository.saveAndFlush(blueprintModel)
122 } catch (ex: DataIntegrityViolationException) {
123 throw BluePrintException(ErrorCode.CONFLICT_ADDING_RESOURCE.value, "The blueprint entry " +
124 "is already exist in database: ${ex.message}", ex)