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