8001508149508c79d1828d5a7f016372b34eac9f
[ccsdk/features.git] /
1 /*
2  * ============LICENSE_START=======================================================
3  * ONAP : ccsdk features
4  * ================================================================================
5  * Copyright (C) 2021 highstreet technologies GmbH Intellectual Property.
6  * All rights reserved.
7  * ================================================================================
8  * Licensed under the Apache License, Version 2.0 (the "License");
9  * you may not use this file except in compliance with the License.
10  * You may obtain a copy of the License at
11  *
12  *     http://www.apache.org/licenses/LICENSE-2.0
13  *
14  * Unless required by applicable law or agreed to in writing, software
15  * distributed under the License is distributed on an "AS IS" BASIS,
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17  * See the License for the specific language governing permissions and
18  * limitations under the License.
19  * ============LICENSE_END=========================================================
20  *
21  */
22 package org.onap.ccsdk.features.sdnr.wt.dataprovider.database.sqldb.query;
23
24 import java.util.ArrayList;
25 import java.util.Arrays;
26 import java.util.List;
27 import java.util.Map;
28 import org.eclipse.jdt.annotation.Nullable;
29 import org.onap.ccsdk.features.sdnr.wt.dataprovider.database.sqldb.database.SqlDBMapper;
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.EntityInput;
31 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.SortOrder;
32 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.entity.input.Filter;
33 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.entity.input.FilterBuilder;
34 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.entity.input.FilterKey;
35 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.entity.input.Pagination;
36 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.entity.input.Sortorder;
37 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.entity.input.SortorderKey;
38
39 public class SelectQuery implements SqlQuery {
40
41     private static final long DEFAULT_PAGESIZE = 20;
42     private static final long DEFAULT_PAGE = 1;
43     private static final List<String> TIMESTAMPPROPERTYNAMES = Arrays.asList("timestamp", "time-stamp", "start", "end");
44     private final String tableName;
45     private final List<Filter> filters;
46     private final List<String> sortExpressions;
47     private long page;
48     private long pageSize;
49     private final List<String> fields;
50     private final List<String> groups;
51
52     public SelectQuery(String tableName) {
53         this(tableName, Arrays.asList("*"), null);
54     }
55
56     public SelectQuery(String tableName, List<String> fields, String controllerId) {
57         this.tableName = tableName;
58         this.fields = fields;
59         this.filters = new ArrayList<>();
60         this.sortExpressions = new ArrayList<>();
61         this.groups = new ArrayList<>();
62         this.page = DEFAULT_PAGE;
63         this.pageSize = DEFAULT_PAGESIZE;
64         if (controllerId != null) {
65             this.addFilter(SqlDBMapper.ODLID_DBCOL, controllerId);
66         }
67     }
68
69     public SelectQuery(String tableName, String field, String controllerId) {
70         this(tableName, Arrays.asList(field), controllerId);
71     }
72
73     public SelectQuery(String tableName, EntityInput input) {
74         this(tableName, input, null);
75     }
76
77     public SelectQuery(String tableName, EntityInput input, String controllerId) {
78         this(tableName);
79         Map<FilterKey, Filter> filter = input != null ? input.getFilter() : null;
80         if (filter != null && filter.size() > 0) {
81             for (Filter f : filter.values()) {
82                 this.addFilter(f.getProperty(), f.getFiltervalue());
83             }
84         }
85         if (controllerId != null) {
86             this.addFilter(SqlDBMapper.ODLID_DBCOL, controllerId);
87         }
88
89         Map<SortorderKey, Sortorder> so = input.getSortorder();
90         if (so != null && so.size() > 0) {
91             for (Sortorder s : so.values()) {
92                 this.addSortOrder(s.getProperty(),
93                         s.getSortorder() == SortOrder.Ascending ? "ASC" : "DESC");
94             }
95         }
96         Pagination pagination = input.getPagination();
97         if (pagination != null) {
98             this.setPagination(pagination.getPage().longValue(), pagination.getSize().longValue());
99         } else {
100             this.setPagination(1, 30);
101         }
102
103     }
104
105     public void addFilter(String property, String filtervalue) {
106         this.filters.add(new FilterBuilder().setProperty(property).setFiltervalue(filtervalue).build());
107
108     }
109
110     public void addSortOrder(String col, String order) {
111         this.sortExpressions.add(String.format("`%s` %s", col, order));
112     }
113
114     public void setPagination(long page, long pageSize) {
115         this.page = page;
116         this.pageSize = pageSize;
117     }
118
119     public void setPagination(@Nullable Pagination pagination) {
120         long page = DEFAULT_PAGE;
121         long pageSize = DEFAULT_PAGESIZE;
122         if(pagination!=null) {
123             if(pagination.getPage()!=null) {
124                 page = pagination.getPage().longValue();
125             }
126             if(pagination.getSize()!=null) {
127                 pageSize = pagination.getSize().longValue();
128             }
129         }
130         this.setPagination(page, pageSize);
131
132     }
133
134     @Override
135     public String toSql() {
136         StringBuilder sb = new StringBuilder();
137         if (this.fields.size() == 1 && this.fields.contains("*")) {
138             sb.append(String.format("SELECT * FROM `%s`", this.tableName));
139         } else {
140             sb.append(String.format("SELECT `%s` FROM `%s`", String.join("`,`", this.fields), this.tableName));
141         }
142         sb.append(SqlQuery.getWhereExpression(this.filters));
143         if (this.groups.size() > 0) {
144             sb.append(String.format(" GROUP BY `%s`", String.join("`,`", this.groups)));
145         }
146         if (this.sortExpressions.size() > 0) {
147             sb.append(" ORDER BY " + String.join(",", this.sortExpressions));
148         }
149         sb.append(String.format(" LIMIT %d,%d;", (this.page - 1) * this.pageSize, this.pageSize));
150         return sb.toString();
151     }
152
153     public long getPage() {
154         return this.page;
155     }
156
157     public long getPageSize() {
158         return this.pageSize;
159     }
160
161     public SelectQuery groupBy(String group) {
162         this.groups.add(group);
163         return this;
164     }
165
166 }