2 * ============LICENSE_START=======================================================
3 * Copyright (C) 2019-2020 Nordix Foundation.
4 * Modifications Copyright (C) 2019 AT&T Intellectual Property. All rights reserved.
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.onap.policy.models.tosca.authorative.provider;
24 import java.util.ArrayList;
25 import java.util.Collections;
26 import java.util.List;
28 import javax.ws.rs.core.Response;
29 import javax.ws.rs.core.Response.Status;
30 import lombok.NonNull;
31 import org.apache.commons.collections4.CollectionUtils;
32 import org.onap.policy.models.base.PfConceptKey;
33 import org.onap.policy.models.base.PfModelException;
34 import org.onap.policy.models.base.PfModelRuntimeException;
35 import org.onap.policy.models.dao.PfDao;
36 import org.onap.policy.models.tosca.authorative.concepts.ToscaEntity;
37 import org.onap.policy.models.tosca.authorative.concepts.ToscaPolicy;
38 import org.onap.policy.models.tosca.authorative.concepts.ToscaPolicyFilter;
39 import org.onap.policy.models.tosca.authorative.concepts.ToscaPolicyType;
40 import org.onap.policy.models.tosca.authorative.concepts.ToscaPolicyTypeFilter;
41 import org.onap.policy.models.tosca.authorative.concepts.ToscaServiceTemplate;
42 import org.onap.policy.models.tosca.simple.concepts.JpaToscaServiceTemplate;
43 import org.onap.policy.models.tosca.simple.provider.SimpleToscaProvider;
44 import org.onap.policy.models.tosca.utils.ToscaServiceTemplateUtils;
45 import org.slf4j.Logger;
46 import org.slf4j.LoggerFactory;
49 * This class provides the provision of information on TOSCA concepts in the database to callers.
51 * @author Liam Fallon (liam.fallon@est.tech)
53 public class AuthorativeToscaProvider {
54 private static final Logger LOGGER = LoggerFactory.getLogger(AuthorativeToscaProvider.class);
56 // TODO: In next release this locking mechanism should be removed and replaced with proper session handling
57 private static final Object providerLockObject = "providerLockObject";
60 * Get a service template.
62 * @param dao the DAO to use to access the database
63 * @param name the name of the control loop to get.
64 * @param version the version of the control loop to get.
65 * @return the control loops found
66 * @throws PfModelException on errors getting control loops
68 public ToscaServiceTemplate getServiceTemplate(@NonNull final PfDao dao, final String name, final String version)
69 throws PfModelException {
71 synchronized (providerLockObject) {
72 LOGGER.debug("->getServiceTemplate: name={}, version={}", name, version);
74 ToscaServiceTemplate gotServiceTemplate = new SimpleToscaProvider().getServiceTemplate(dao).toAuthorative();
76 LOGGER.debug("<-getServiceTemplate: name={}, version={}, gotServiceTemplate={}", name, version,
78 return gotServiceTemplate;
83 * Create a service template.
85 * @param dao the DAO to use to access the database
86 * @param serviceTemplate the service template to be created.
87 * @return the TOSCA service template that was created
88 * @throws PfModelException on errors creating the service template
90 public ToscaServiceTemplate createServiceTemplate(@NonNull final PfDao dao,
91 @NonNull final ToscaServiceTemplate serviceTemplate) throws PfModelException {
93 synchronized (providerLockObject) {
94 LOGGER.debug("->createServiceTemplate: serviceTemplate={}", serviceTemplate);
96 ToscaServiceTemplate createdServiceTemplate = new SimpleToscaProvider()
97 .appendToServiceTemplate(dao, new JpaToscaServiceTemplate(serviceTemplate)).toAuthorative();
99 LOGGER.debug("<-createServiceTemplate: createdServiceTemplate={}", createdServiceTemplate);
100 return createdServiceTemplate;
105 * Delete a service template.
107 * @param dao the DAO to use to access the database
108 * @param name the name of the service template to delete.
109 * @param version the version of the service template to delete.
110 * @return the TOSCA service template that was deleted
111 * @throws PfModelException on errors deleting the control loop
113 public ToscaServiceTemplate deleteServiceTemplate(@NonNull final PfDao dao, @NonNull final String name,
114 @NonNull final String version) throws PfModelException {
116 synchronized (providerLockObject) {
117 LOGGER.debug("->deleteServiceTemplate: name={}, version={}", name, version);
119 ToscaServiceTemplate deletedServiceTemplate =
120 new SimpleToscaProvider().deleteServiceTemplate(dao).toAuthorative();
122 LOGGER.debug("<-deleteServiceTemplate: name={}, version={}, deletedServiceTemplate={}", name, version,
123 deletedServiceTemplate);
124 return deletedServiceTemplate;
131 * @param dao the DAO to use to access the database
132 * @param name the name of the policy type to get.
133 * @param version the version of the policy type to get.
134 * @return the policy types found
135 * @throws PfModelException on errors getting policy types
137 public ToscaServiceTemplate getPolicyTypes(@NonNull final PfDao dao, final String name, final String version)
138 throws PfModelException {
140 synchronized (providerLockObject) {
141 LOGGER.debug("->getPolicyTypes: name={}, version={}", name, version);
143 JpaToscaServiceTemplate jpaServiceTemplate = new SimpleToscaProvider().getPolicyTypes(dao, name, version);
145 ToscaServiceTemplate serviceTemplate = jpaServiceTemplate.toAuthorative();
147 LOGGER.debug("<-getPolicyTypes: name={}, version={}, serviceTemplate={}", name, version, serviceTemplate);
148 return serviceTemplate;
155 * @param dao the DAO to use to access the database
156 * @param name the name of the policy type to get, set to null to get all policy types
157 * @param version the version of the policy type to get, set to null to get all versions
158 * @return the policy types found
159 * @throws PfModelException on errors getting policy types
161 public List<ToscaPolicyType> getPolicyTypeList(@NonNull final PfDao dao, final String name, final String version)
162 throws PfModelException {
164 synchronized (providerLockObject) {
165 LOGGER.debug("->getPolicyTypeList: name={}, version={}", name, version);
167 List<ToscaPolicyType> policyTypeList;
170 policyTypeList = new ArrayList<>(new SimpleToscaProvider().getPolicyTypes(dao, name, version)
171 .toAuthorative().getPolicyTypes().values());
172 } catch (PfModelRuntimeException pfme) {
173 return handlePfModelRuntimeException(pfme);
176 LOGGER.debug("<-getPolicyTypeList: name={}, version={}, policyTypeList={}", name, version, policyTypeList);
177 return policyTypeList;
182 * Get filtered policy types.
184 * @param dao the DAO to use to access the database
185 * @param filter the filter for the policy types to get
186 * @return the policy types found
187 * @throws PfModelException on errors getting policy types
189 public ToscaServiceTemplate getFilteredPolicyTypes(@NonNull final PfDao dao,
190 @NonNull final ToscaPolicyTypeFilter filter) throws PfModelException {
192 synchronized (providerLockObject) {
193 LOGGER.debug("->getFilteredPolicyTypes: filter={}", filter);
194 SimpleToscaProvider simpleToscaProvider = new SimpleToscaProvider();
196 final JpaToscaServiceTemplate dbServiceTemplate = simpleToscaProvider.getPolicyTypes(dao, null, null);
198 List<ToscaPolicyType> filteredPolicyTypes = dbServiceTemplate.getPolicyTypes().toAuthorativeList();
199 filteredPolicyTypes = filter.filter(filteredPolicyTypes);
201 if (CollectionUtils.isEmpty(filteredPolicyTypes)) {
202 throw new PfModelRuntimeException(Response.Status.NOT_FOUND,
203 "policy types for filter " + filter.toString() + " do not exist");
206 JpaToscaServiceTemplate filteredServiceTemplate = new JpaToscaServiceTemplate();
208 for (ToscaPolicyType policyType : filteredPolicyTypes) {
209 JpaToscaServiceTemplate cascadedServiceTemplate = simpleToscaProvider
210 .getCascadedPolicyTypes(dbServiceTemplate, policyType.getName(), policyType.getVersion());
212 filteredServiceTemplate =
213 ToscaServiceTemplateUtils.addFragment(filteredServiceTemplate, cascadedServiceTemplate);
216 ToscaServiceTemplate returnServiceTemplate = filteredServiceTemplate.toAuthorative();
218 LOGGER.debug("<-getFilteredPolicyTypes: filter={}, serviceTemplate={}", filter, returnServiceTemplate);
219 return returnServiceTemplate;
224 * Get filtered policy types.
226 * @param dao the DAO to use to access the database
227 * @param filter the filter for the policy types to get
228 * @return the policy types found
229 * @throws PfModelException on errors getting policy types
231 public List<ToscaPolicyType> getFilteredPolicyTypeList(@NonNull final PfDao dao,
232 @NonNull final ToscaPolicyTypeFilter filter) throws PfModelException {
234 LOGGER.debug("->getFilteredPolicyTypeList: filter={}", filter);
236 List<ToscaPolicyType> filteredPolicyTypeList = filter.filter(getPolicyTypeList(dao, null, null));
238 LOGGER.debug("<-getFilteredPolicyTypeList: filter={}, filteredPolicyTypeList={}", filter,
239 filteredPolicyTypeList);
241 return filteredPolicyTypeList;
245 * Create policy types.
247 * @param dao the DAO to use to access the database
248 * @param serviceTemplate the service template containing the definition of the policy types to be created
249 * @return the TOSCA service template containing the created policy types
250 * @throws PfModelException on errors creating policy types
252 public ToscaServiceTemplate createPolicyTypes(@NonNull final PfDao dao,
253 @NonNull final ToscaServiceTemplate serviceTemplate) throws PfModelException {
255 synchronized (providerLockObject) {
256 LOGGER.debug("->createPolicyTypes: serviceTemplate={}", serviceTemplate);
258 ToscaServiceTemplate createdServiceTemplate = new SimpleToscaProvider()
259 .createPolicyTypes(dao, new JpaToscaServiceTemplate(serviceTemplate)).toAuthorative();
261 LOGGER.debug("<-createPolicyTypes: createdServiceTemplate={}", createdServiceTemplate);
262 return createdServiceTemplate;
267 * Update policy types.
269 * @param dao the DAO to use to access the database
270 * @param serviceTemplate the service template containing the definition of the policy types to be modified
271 * @return the TOSCA service template containing the modified policy types
272 * @throws PfModelException on errors updating policy types
274 public ToscaServiceTemplate updatePolicyTypes(@NonNull final PfDao dao,
275 @NonNull final ToscaServiceTemplate serviceTemplate) throws PfModelException {
277 synchronized (providerLockObject) {
278 LOGGER.debug("->updatePolicyTypes: serviceTemplate={}", serviceTemplate);
280 ToscaServiceTemplate updatedServiceTemplate = new SimpleToscaProvider()
281 .updatePolicyTypes(dao, new JpaToscaServiceTemplate(serviceTemplate)).toAuthorative();
283 LOGGER.debug("<-updatePolicyTypes: updatedServiceTemplate={}", updatedServiceTemplate);
284 return updatedServiceTemplate;
289 * Delete policy type.
291 * @param dao the DAO to use to access the database
292 * @param name the name of the policy type to delete.
293 * @param version the version of the policy type to delete.
294 * @return the TOSCA service template containing the policy type that was deleted
295 * @throws PfModelException on errors deleting policy types
297 public ToscaServiceTemplate deletePolicyType(@NonNull final PfDao dao, @NonNull final String name,
298 @NonNull final String version) throws PfModelException {
300 synchronized (providerLockObject) {
301 LOGGER.debug("->deletePolicyType: name={}, version={}", name, version);
303 ToscaServiceTemplate deletedServiceTemplate =
304 new SimpleToscaProvider().deletePolicyType(dao, new PfConceptKey(name, version)).toAuthorative();
306 LOGGER.debug("<-deletePolicyType: name={}, version={}, deletedServiceTemplate={}", name, version,
307 deletedServiceTemplate);
308 return deletedServiceTemplate;
315 * @param dao the DAO to use to access the database
316 * @param name the name of the policy to get.
317 * @param version the version of the policy to get.
318 * @return the policies found
319 * @throws PfModelException on errors getting policies
321 public ToscaServiceTemplate getPolicies(@NonNull final PfDao dao, final String name, final String version)
322 throws PfModelException {
324 synchronized (providerLockObject) {
325 LOGGER.debug("->getPolicies: name={}, version={}", name, version);
327 ToscaServiceTemplate gotServiceTemplate =
328 new SimpleToscaProvider().getPolicies(dao, name, version).toAuthorative();
330 LOGGER.debug("<-getPolicies: name={}, version={}, gotServiceTemplate={}", name, version,
332 return gotServiceTemplate;
339 * @param dao the DAO to use to access the database
340 * @param name the name of the policy to get, null to get all policies
341 * @param version the version of the policy to get, null to get all versions of a policy
342 * @return the policies found
343 * @throws PfModelException on errors getting policies
345 public List<ToscaPolicy> getPolicyList(@NonNull final PfDao dao, final String name, final String version)
346 throws PfModelException {
348 synchronized (providerLockObject) {
349 LOGGER.debug("->getPolicyList: name={}, version={}", name, version);
351 List<ToscaPolicy> policyList;
354 policyList = asConceptList(new SimpleToscaProvider().getPolicies(dao, name, version).toAuthorative()
355 .getToscaTopologyTemplate().getPolicies());
356 } catch (PfModelRuntimeException pfme) {
357 return handlePfModelRuntimeException(pfme);
360 LOGGER.debug("<-getPolicyList: name={}, version={}, policyList={}", name, version, policyList);
366 * Get filtered policies.
368 * @param dao the DAO to use to access the database
369 * @param filter the filter for the policies to get
370 * @return the policies found
371 * @throws PfModelException on errors getting policies
373 public ToscaServiceTemplate getFilteredPolicies(@NonNull final PfDao dao, @NonNull final ToscaPolicyFilter filter)
374 throws PfModelException {
376 synchronized (providerLockObject) {
377 LOGGER.debug("->getFilteredPolicies: filter={}", filter);
378 String version = ToscaPolicyFilter.LATEST_VERSION.equals(filter.getVersion()) ? null : filter.getVersion();
380 SimpleToscaProvider simpleToscaProvider = new SimpleToscaProvider();
381 final JpaToscaServiceTemplate dbServiceTemplate =
382 simpleToscaProvider.getPolicies(dao, filter.getName(), version);
384 List<ToscaPolicy> filteredPolicies =
385 dbServiceTemplate.getTopologyTemplate().getPolicies().toAuthorativeList();
386 filteredPolicies = filter.filter(filteredPolicies);
388 if (CollectionUtils.isEmpty(filteredPolicies)) {
389 throw new PfModelRuntimeException(Response.Status.NOT_FOUND,
390 "policies for filter " + filter.toString() + " do not exist");
393 JpaToscaServiceTemplate filteredServiceTemplate = new JpaToscaServiceTemplate();
395 for (ToscaPolicy policy : filteredPolicies) {
396 JpaToscaServiceTemplate cascadedServiceTemplate =
397 simpleToscaProvider.getCascadedPolicies(dbServiceTemplate, policy.getName(), policy.getVersion());
399 filteredServiceTemplate =
400 ToscaServiceTemplateUtils.addFragment(filteredServiceTemplate, cascadedServiceTemplate);
403 ToscaServiceTemplate returnServiceTemplate = filteredServiceTemplate.toAuthorative();
405 LOGGER.debug("<-getFilteredPolicies: filter={}, serviceTemplate={}", filter, returnServiceTemplate);
406 return returnServiceTemplate;
411 * Get filtered policies.
413 * @param dao the DAO to use to access the database
414 * @param filter the filter for the policies to get
415 * @return the policies found
416 * @throws PfModelException on errors getting policies
418 public List<ToscaPolicy> getFilteredPolicyList(@NonNull final PfDao dao, @NonNull final ToscaPolicyFilter filter)
419 throws PfModelException {
421 LOGGER.debug("->getFilteredPolicyList: filter={}", filter);
422 String version = ToscaPolicyFilter.LATEST_VERSION.equals(filter.getVersion()) ? null : filter.getVersion();
424 List<ToscaPolicy> policyList = filter.filter(getPolicyList(dao, filter.getName(), version));
426 LOGGER.debug("<-getFilteredPolicyList: filter={}, policyList={}", filter, policyList);
433 * @param dao the DAO to use to access the database
434 * @param serviceTemplate the service template containing the definitions of the new policies to be created.
435 * @return the TOSCA service template containing the policy types that were created
436 * @throws PfModelException on errors creating policies
438 public ToscaServiceTemplate createPolicies(@NonNull final PfDao dao,
439 @NonNull final ToscaServiceTemplate serviceTemplate) throws PfModelException {
441 synchronized (providerLockObject) {
442 LOGGER.debug("->createPolicies: serviceTemplate={}", serviceTemplate);
444 ToscaServiceTemplate createdServiceTemplate = new SimpleToscaProvider()
445 .createPolicies(dao, new JpaToscaServiceTemplate(serviceTemplate)).toAuthorative();
447 LOGGER.debug("<-createPolicies: createdServiceTemplate={}", createdServiceTemplate);
448 return createdServiceTemplate;
455 * @param dao the DAO to use to access the database
456 * @param serviceTemplate the service template containing the definitions of the policies to be updated.
457 * @return the TOSCA service template containing the policies that were updated
458 * @throws PfModelException on errors updating policies
460 public ToscaServiceTemplate updatePolicies(@NonNull final PfDao dao,
461 @NonNull final ToscaServiceTemplate serviceTemplate) throws PfModelException {
463 synchronized (providerLockObject) {
464 LOGGER.debug("->updatePolicies: serviceTemplate={}", serviceTemplate);
466 ToscaServiceTemplate updatedServiceTemplate = new SimpleToscaProvider()
467 .updatePolicies(dao, new JpaToscaServiceTemplate(serviceTemplate)).toAuthorative();
469 LOGGER.debug("<-updatePolicies: updatedServiceTemplate={}", updatedServiceTemplate);
470 return updatedServiceTemplate;
477 * @param dao the DAO to use to access the database
478 * @param name the name of the policy to delete.
479 * @param version the version of the policy to delete.
480 * @return the TOSCA service template containing the policy that was deleted
481 * @throws PfModelException on errors deleting policies
483 public ToscaServiceTemplate deletePolicy(@NonNull final PfDao dao, @NonNull final String name,
484 @NonNull final String version) throws PfModelException {
486 synchronized (providerLockObject) {
487 LOGGER.debug("->deletePolicy: name={}, version={}", name, version);
489 ToscaServiceTemplate deletedServiceTemplate =
490 new SimpleToscaProvider().deletePolicy(dao, new PfConceptKey(name, version)).toAuthorative();
492 LOGGER.debug("<-deletePolicy: name={}, version={}, deletedServiceTemplate={}", name, version,
493 deletedServiceTemplate);
494 return deletedServiceTemplate;
499 * Return the contents of a list of maps as a plain list.
501 * @param listOfMaps the list of maps
502 * @return the plain list
504 private <T> List<T> asConceptList(final List<Map<String, T>> listOfMaps) {
505 List<T> returnList = new ArrayList<>();
506 for (Map<String, T> conceptMap : listOfMaps) {
507 for (T concept : conceptMap.values()) {
508 returnList.add(concept);
516 * Handle a PfModelRuntimeException on a list call.
518 * @param pfme the model exception
519 * @return an empty list on 404
521 private <T extends ToscaEntity> List<T> handlePfModelRuntimeException(final PfModelRuntimeException pfme) {
522 if (Status.NOT_FOUND.equals(pfme.getErrorResponse().getResponseCode())) {
523 LOGGER.trace("request did not find any results", pfme);
524 return Collections.emptyList();