[SDC-29] Amdocs OnBoard 1707 initial commit.
[sdc.git] / openecomp-be / lib / openecomp-sdc-vendor-software-product-lib / openecomp-sdc-vendor-software-product-core / src / main / java / org / openecomp / sdc / vendorsoftwareproduct / dao / impl / ComponentDaoCassandraImpl.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * SDC
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
10  * 
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  * 
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=========================================================
19  */
20
21 package org.openecomp.sdc.vendorsoftwareproduct.dao.impl;
22
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;
40
41 import java.util.Arrays;
42 import java.util.Collection;
43 import java.util.Collections;
44
45 public class ComponentDaoCassandraImpl extends CassandraBaseDao<ComponentEntity>
46     implements ComponentDao {
47
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);
55
56   @Override
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());
62
63
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"))));
68
69     VersioningManagerFactory.getInstance().createInterface()
70         .register(versionableEntityType, metadata);
71   }
72
73   @Override
74   protected Mapper<ComponentEntity> getMapper() {
75     return mapper;
76   }
77
78   @Override
79   protected Object[] getKeys(ComponentEntity entity) {
80     return new Object[]{entity.getVspId(), versionMapper.toUDT(entity.getVersion()),
81         entity.getId()};
82   }
83
84   @Override
85   public void update(ComponentEntity entity) {
86     accessor.updateCompositionData(entity.getVspId(), versionMapper.toUDT(entity.getVersion()),
87         entity.getId(), entity.getCompositionData());
88   }
89
90   @Override
91   public Collection<ComponentEntity> list(ComponentEntity entity) {
92     return accessor.list(entity.getVspId(), versionMapper.toUDT(entity.getVersion())).all();
93   }
94
95   @Override
96   public ComponentEntity getQuestionnaireData(String vspId, Version version, String componentId) {
97     return accessor.getQuestionnaireData(vspId, versionMapper.toUDT(version), componentId);
98   }
99
100   @Override
101   public void updateQuestionnaireData(String vspId, Version version, String componentId,
102                                       String questionnaireData) {
103     accessor.updateQuestionnaireData(questionnaireData, vspId, versionMapper.toUDT(version), componentId);
104   }
105
106   @Override
107   public Collection<ComponentEntity> listQuestionnaires(String vspId, Version version) {
108     return accessor.listQuestionnaires(vspId, versionMapper.toUDT(version)).all();
109   }
110
111   @Override
112   public Collection<ComponentEntity> listCompositionAndQuestionnaire(String vspId, Version version){
113     return accessor.listCompositionAndQuestionnaire(vspId, versionMapper.toUDT(version)).all();
114   }
115
116   @Override
117   public void deleteAll(String vspId, Version version) {
118     accessor.deleteAll(vspId, version);
119   }
120
121   @Accessor
122   interface ComponentAccessor {
123
124     @Query(
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);
128
129     @Query(
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);
133
134     @Query(
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);
138
139     @Query(
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);
143
144     @Query(
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);
149
150     @Query(
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,
154                                       String id);
155
156     @Query("delete from vsp_component where vsp_id=? and version=?")
157     ResultSet deleteAll(String vspId, Version version);
158   }
159 }