Sync Integ to Master
[sdc.git] / catalog-dao / src / main / java / org / openecomp / sdc / be / dao / cassandra / schema / tables / DistribNotifEventTableDesc.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.be.dao.cassandra.schema.tables;
22
23 import java.util.Map;
24
25 import org.apache.commons.lang3.tuple.ImmutablePair;
26 import org.openecomp.sdc.be.resources.data.auditing.AuditingTypesConstants;
27
28 import com.datastax.driver.core.DataType;
29
30 public class DistribNotifEventTableDesc extends DistribBaseEventTableDesc {
31
32         @Override
33         protected void updateColumnDistribDescription(Map<String, ImmutablePair<DataType, Boolean>> columns) {
34                 for (DNEFieldsDescription field : DNEFieldsDescription.values()) {
35                         columns.put(field.getName(), new ImmutablePair<DataType, Boolean>(field.type, field.indexed));
36                 }
37         //replace the base indexed flag value with the correct one for a given table:
38         columns.put(DistFieldsDescription.SERVICE_INST_ID.getName(),
39                 new ImmutablePair<DataType, Boolean>(DistFieldsDescription.SERVICE_INST_ID.getType(), true));
40         }
41
42         @Override
43         public String getTableName() {
44                 return AuditingTypesConstants.DISTRIBUTION_NOTIFICATION_EVENT_TYPE;
45         }
46
47         enum DNEFieldsDescription {
48                 TOPIC_NAME("topic_name", DataType.varchar(), false),
49                 MODIFIER("modifier", DataType.varchar(), false), 
50                 CURR_STATE("curr_state", DataType.varchar(), false), 
51                 CURR_VERSION("curr_version", DataType.varchar(), false), 
52                 DID("did", DataType.varchar(), true), 
53                 RESOURCE_NAME("resource_name", DataType.varchar(), false), 
54                 RESOURCE_TYPE("resource_type", DataType.varchar(), false),
55                 ENV_ID("env_id", DataType.varchar(), false),
56                 VNF_WORKLOAD_CONTEXT("vnf_workload_context", DataType.varchar(), false),
57                 TENANT("tenant", DataType.varchar(), false);
58
59                 private String name;
60                 private DataType type;
61                 private boolean indexed;
62
63                 DNEFieldsDescription(String name, DataType type, boolean indexed) {
64                         this.name = name;
65                         this.type = type;
66                         this.indexed = indexed;
67                 }
68
69                 public String getName() {
70                         return name;
71                 }
72
73                 public DataType getType() {
74                         return type;
75                 }
76
77                 public boolean isIndexed() {
78                         return indexed;
79                 }
80         }
81
82 }