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.dao.impl;
23 import com.datastax.driver.core.ResultSet;
24 import com.datastax.driver.core.UDTValue;
25 import com.datastax.driver.mapping.Mapper;
26 import com.datastax.driver.mapping.Result;
27 import com.datastax.driver.mapping.UDTMapper;
28 import com.datastax.driver.mapping.annotations.Accessor;
29 import com.datastax.driver.mapping.annotations.Query;
30 import org.openecomp.core.dao.impl.CassandraBaseDao;
31 import org.openecomp.core.nosqldb.api.NoSqlDb;
32 import org.openecomp.core.nosqldb.factory.NoSqlDbFactory;
33 import org.openecomp.sdc.vendorsoftwareproduct.VendorSoftwareProductConstants;
34 import org.openecomp.sdc.vendorsoftwareproduct.dao.ComponentDao;
35 import org.openecomp.sdc.vendorsoftwareproduct.dao.type.ComponentEntity;
36 import org.openecomp.sdc.versioning.VersioningManagerFactory;
37 import org.openecomp.sdc.versioning.dao.types.Version;
38 import org.openecomp.sdc.versioning.types.UniqueValueMetadata;
39 import org.openecomp.sdc.versioning.types.VersionableEntityMetadata;
41 import java.util.Arrays;
42 import java.util.Collection;
43 import java.util.Collections;
45 public class ComponentDaoCassandraImpl extends CassandraBaseDao<ComponentEntity>
46 implements ComponentDao {
48 private static final NoSqlDb noSqlDb = NoSqlDbFactory.getInstance().createInterface();
49 private static final Mapper<ComponentEntity> mapper =
50 noSqlDb.getMappingManager().mapper(ComponentEntity.class);
51 private static final ComponentAccessor accessor =
52 noSqlDb.getMappingManager().createAccessor(ComponentAccessor.class);
53 private static final UDTMapper<Version> versionMapper =
54 noSqlDb.getMappingManager().udtMapper(Version.class);
57 public void registerVersioning(String versionableEntityType) {
58 VersionableEntityMetadata metadata = new VersionableEntityMetadata(
59 mapper.getTableMetadata().getName(),
60 mapper.getTableMetadata().getPartitionKey().get(0).getName(),
61 mapper.getTableMetadata().getPartitionKey().get(1).getName());
64 metadata.setUniqueValuesMetadata(Collections.singletonList(new UniqueValueMetadata(
65 VendorSoftwareProductConstants.UniqueValues.COMPONENT_NAME,
66 Arrays.asList(mapper.getTableMetadata().getPartitionKey().get(0).getName(),
67 mapper.getTableMetadata().getPartitionKey().get(1).getName(), "name"))));
69 VersioningManagerFactory.getInstance().createInterface()
70 .register(versionableEntityType, metadata);
74 protected Mapper<ComponentEntity> getMapper() {
79 protected Object[] getKeys(ComponentEntity entity) {
80 return new Object[]{entity.getVspId(), versionMapper.toUDT(entity.getVersion()),
85 public void update(ComponentEntity entity) {
86 accessor.updateCompositionData(entity.getVspId(), versionMapper.toUDT(entity.getVersion()),
87 entity.getId(), entity.getCompositionData());
91 public Collection<ComponentEntity> list(ComponentEntity entity) {
92 return accessor.list(entity.getVspId(), versionMapper.toUDT(entity.getVersion())).all();
96 public ComponentEntity getQuestionnaireData(String vspId, Version version, String componentId) {
97 return accessor.getQuestionnaireData(vspId, versionMapper.toUDT(version), componentId);
101 public void updateQuestionnaireData(String vspId, Version version, String componentId,
102 String questionnaireData) {
103 accessor.updateQuestionnaireData(questionnaireData, vspId, versionMapper.toUDT(version), componentId);
107 public Collection<ComponentEntity> listQuestionnaires(String vspId, Version version) {
108 return accessor.listQuestionnaires(vspId, versionMapper.toUDT(version)).all();
112 public Collection<ComponentEntity> listCompositionAndQuestionnaire(String vspId, Version version){
113 return accessor.listCompositionAndQuestionnaire(vspId, versionMapper.toUDT(version)).all();
117 public void deleteAll(String vspId, Version version) {
118 accessor.deleteAll(vspId, version);
122 interface ComponentAccessor {
125 "select vsp_id, version, component_id, composition_data from vsp_component"
126 + " where vsp_id=? and version=?")
127 Result<ComponentEntity> list(String vspId, UDTValue version);
130 "select vsp_id, version, component_id, composition_data, questionnaire_data from vsp_component"
131 + " where vsp_id=? and version=?")
132 Result<ComponentEntity> listCompositionAndQuestionnaire(String vspId, UDTValue version);
135 "select vsp_id, version, component_id, questionnaire_data from vsp_component"
136 + " where vsp_id=? and version=?")
137 Result<ComponentEntity> listQuestionnaires(String vspId, UDTValue version);
140 "select vsp_id, version, component_id, questionnaire_data from vsp_component"
141 + " where vsp_id=? and version=? and component_id=?")
142 ComponentEntity getQuestionnaireData(String vspId, UDTValue version, String id);
145 "insert into vsp_component (vsp_id, version, component_id, composition_data)"
146 + " values (?,?,?,?)")
147 ResultSet updateCompositionData(String vspId, UDTValue version, String id,
148 String compositionData);
151 "update vsp_component set questionnaire_data=? where vsp_id=? and version=?"
152 + " and component_id=?")
153 ResultSet updateQuestionnaireData(String questionnaireData, String vspId, UDTValue version,
156 @Query("delete from vsp_component where vsp_id=? and version=?")
157 ResultSet deleteAll(String vspId, Version version);