push addional code
[sdc.git] / openecomp-be / lib / openecomp-sdc-model-lib / openecomp-sdc-model-impl / src / main / java / org / openecomp / sdc / model / impl / ServiceTemplateDaoCassandraImpl.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.model.impl;
22
23 import com.datastax.driver.core.UDTValue;
24 import com.datastax.driver.mapping.Mapper;
25 import com.datastax.driver.mapping.Result;
26 import com.datastax.driver.mapping.UDTMapper;
27 import com.datastax.driver.mapping.annotations.Accessor;
28 import com.datastax.driver.mapping.annotations.Query;
29 import org.openecomp.core.model.dao.ServiceTemplateDao;
30 import org.openecomp.core.model.types.ServiceTemplate;
31 import org.openecomp.core.model.types.ServiceTemplateEntity;
32 import org.openecomp.core.nosqldb.api.NoSqlDb;
33 import org.openecomp.core.nosqldb.factory.NoSqlDbFactory;
34 import org.openecomp.sdc.versioning.VersioningManagerFactory;
35 import org.openecomp.sdc.versioning.dao.types.Version;
36 import org.openecomp.sdc.versioning.types.VersionableEntityMetadata;
37
38 import java.util.Collection;
39 import java.util.List;
40 import java.util.stream.Collectors;
41
42 public class ServiceTemplateDaoCassandraImpl implements ServiceTemplateDao {
43
44
45   private static final NoSqlDb noSqlDb = NoSqlDbFactory.getInstance().createInterface();
46   private static final Mapper<ServiceTemplateEntity> mapper =
47       noSqlDb.getMappingManager().mapper(ServiceTemplateEntity.class);
48   private static final VspServiceTemplateAccessor accessor =
49       noSqlDb.getMappingManager().createAccessor(VspServiceTemplateAccessor.class);
50   private static final UDTMapper<Version> versionMapper =
51       noSqlDb.getMappingManager().udtMapper(Version.class);
52
53   @Override
54   public void registerVersioning(String versionableEntityType) {
55     VersioningManagerFactory.getInstance().createInterface()
56         .register(versionableEntityType, new VersionableEntityMetadata(
57             mapper.getTableMetadata().getName(),
58             mapper.getTableMetadata().getPartitionKey().get(0).getName(),
59             mapper.getTableMetadata().getPartitionKey().get(1).getName()));
60   }
61
62   @Override
63   public Collection<ServiceTemplate> list(String vspId, Version version) {
64
65     List<ServiceTemplateEntity> entityList = accessor.list(vspId, version).all();
66     return entityList.stream().map(entity -> entity.getServiceTemplate())
67         .collect(Collectors.toList());
68   }
69
70   @Override
71   public void create(ServiceTemplate entity) {
72     ServiceTemplateEntity vspServiceTemplateEntity = new ServiceTemplateEntity(entity);
73     mapper.save(vspServiceTemplateEntity);
74   }
75
76   @Override
77   public void update(ServiceTemplate entity) {
78     ServiceTemplateEntity vspServiceTemplateEntity = new ServiceTemplateEntity(entity);
79     mapper.save(vspServiceTemplateEntity);
80   }
81
82   @Override
83   public ServiceTemplate get(String vspId, Version version) {
84     return (mapper.get(getKeys(vspId, version))).getServiceTemplate();
85   }
86
87   @Override
88   public void delete(String vspId, Version version) {
89     mapper.delete(vspId, version);
90   }
91
92
93   @Override
94   public Object[] getKeys(String vspId, Version version) {
95     return new Object[]{vspId, versionMapper.toUDT(version)};
96   }
97
98   @Override
99   public ServiceTemplate getTemplateInfo(String vspId, Version version, String name) {
100     ServiceTemplateEntity serviceTemplateEntity =
101         accessor.getTemplateInfo(vspId, versionMapper.toUDT(version), name).one();
102     if (serviceTemplateEntity == null) {
103       return null;
104     }
105     return serviceTemplateEntity.getServiceTemplate();
106   }
107
108   @Override
109   public String getBase(String vspId, Version version) {
110     Result<ServiceTemplateEntity> element = accessor.getBase(vspId, versionMapper.toUDT(version));
111     if (element != null) {
112       ServiceTemplateEntity vspServiceTemplateEntity = element.one();
113       if (vspServiceTemplateEntity != null) {
114         return element.one().getBaseName();
115       }
116     }
117     return null;
118   }
119
120
121   @Accessor
122   interface VspServiceTemplateAccessor {
123
124     @Query("SELECT vsp_id, version, name, base_name ,content_data FROM vsp_service_template")
125     Result<ServiceTemplateEntity> listAll();
126
127     @Query(
128         "SELECT vsp_id, version, name, base_name ,content_data"
129                 + " FROM vsp_service_template where vsp_id=? and version=?")
130     Result<ServiceTemplateEntity> list(String vspId, Version version);
131
132
133     @Query(
134         "SELECT vsp_id, version, name, base_name ,content_data "
135                 + "FROM vsp_service_template where vsp_id=? and version=? and name=?")
136     Result<ServiceTemplateEntity> getTemplateInfo(String vspId, UDTValue version, String name);
137
138     @Query(
139         "SELECT vsp_id, version, name, base_name  "
140                 + "FROM vsp_service_template where vsp_id=? and version=?")
141     Result<ServiceTemplateEntity> getBase(String vspId, UDTValue version);
142   }
143
144
145 }