aboutsummaryrefslogtreecommitdiffstats
path: root/ms/blueprintsprocessor/functions/config-snapshots/src/main/kotlin/org/onap/ccsdk/cds/blueprintsprocessor/functions/config/snapshots/db/ResourceConfigSnapshotService.kt
blob: 06146c200489839be3629493dd9d22c11ade2dc5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
/*
 * Copyright (C) 2019 Bell Canada.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.onap.ccsdk.cds.blueprintsprocessor.functions.config.snapshots.db

import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.withContext
import org.apache.logging.log4j.util.Strings
import org.onap.ccsdk.cds.blueprintsprocessor.functions.config.snapshots.db.ResourceConfigSnapshot.Status.RUNNING
import org.onap.ccsdk.cds.controllerblueprints.core.BluePrintException
import org.slf4j.LoggerFactory
import org.springframework.dao.DataIntegrityViolationException
import org.springframework.stereotype.Service
import java.util.UUID

/**
 * ResourceConfigSnapshot managing service.
 *
 * @author Serge Simard
 * @version 1.0
 */
@Service
open class ResourceConfigSnapshotService(private val resourceConfigSnapshotRepository: ResourceConfigSnapshotRepository) {

    private val log = LoggerFactory.getLogger(ResourceConfigSnapshotService::class.toString())

    suspend fun findAllByResourceIdForStatus(
        resourceId: String,
        status: ResourceConfigSnapshot.Status
    ): List<ResourceConfigSnapshot>? =
        withContext(Dispatchers.IO) {
            resourceConfigSnapshotRepository.findByResourceIdAndStatusOrderByCreatedDateDesc(resourceId, status)
        }

    suspend fun findAllByResourceId(
        resourceId: String
    ): List<ResourceConfigSnapshot>? =
        withContext(Dispatchers.IO) {
            resourceConfigSnapshotRepository.findByResourceIdOrderByCreatedDateDesc(resourceId)
        }

    suspend fun findAllByResourceTypeForStatus(
        resourceType: String,
        status: ResourceConfigSnapshot.Status
    ): List<ResourceConfigSnapshot>? =
        withContext(Dispatchers.IO) {
            resourceConfigSnapshotRepository.findByResourceTypeAndStatusOrderByCreatedDateDesc(resourceType, status)
        }

    suspend fun findAllByResourceType(
        resourceType: String
    ): List<ResourceConfigSnapshot>? =
        withContext(Dispatchers.IO) {
            resourceConfigSnapshotRepository.findByResourceTypeOrderByCreatedDateDesc(resourceType)
        }

    suspend fun findByResourceIdAndResourceTypeAndStatus(
        resourceId: String,
        resourceType: String,
        status: ResourceConfigSnapshot.Status = RUNNING
    ): String =
        withContext(Dispatchers.IO) {
            resourceConfigSnapshotRepository.findByResourceIdAndResourceTypeAndStatus(resourceId, resourceType, status)
                ?.config_snapshot ?: Strings.EMPTY
        }

    suspend fun write(
        snapshot: String,
        resId: String,
        resType: String,
        status: ResourceConfigSnapshot.Status = RUNNING
    ): ResourceConfigSnapshot =
        withContext(Dispatchers.IO) {

            val resourceConfigSnapshotEntry = ResourceConfigSnapshot()
            resourceConfigSnapshotEntry.id = UUID.randomUUID().toString()
            resourceConfigSnapshotEntry.resourceId = resId
            resourceConfigSnapshotEntry.resourceType = resType
            resourceConfigSnapshotEntry.status = status
            resourceConfigSnapshotEntry.config_snapshot = snapshot

            // Overwrite configuration snapshot entry of resId/resType
            if (resId.isNotEmpty() && resType.isNotEmpty()) {
                resourceConfigSnapshotRepository.findByResourceIdAndResourceTypeAndStatus(resId, resType, status)
                    ?.let {
                        log.info(
                            "Overwriting configuration snapshot entry for resourceId=($resId), " +
                                "resourceType=($resType), status=($status)"
                        )
                        resourceConfigSnapshotRepository.deleteByResourceIdAndResourceTypeAndStatus(resId, resType, status)
                    }
            }
            var storedSnapshot: ResourceConfigSnapshot
            try {
                storedSnapshot = resourceConfigSnapshotRepository.saveAndFlush(resourceConfigSnapshotEntry)
                log.info(
                    "Stored configuration snapshot for resourceId=($resId), " +
                        "resourceType=($resType), status=($status), " +
                        "dated=(${storedSnapshot.createdDate})"
                )
            } catch (ex: DataIntegrityViolationException) {
                throw BluePrintException("Failed to store configuration snapshot entry.", ex)
            }
            storedSnapshot
        }
}