2 * ============LICENSE_START=======================================================
3 * ONAP : ccsdk features
4 * ================================================================================
5 * Copyright (C) 2021 highstreet technologies GmbH Intellectual Property.
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
12 * http://www.apache.org/licenses/LICENSE-2.0
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=========================================================
22 package org.onap.ccsdk.features.sdnr.wt.dataprovider.database.sqldb.query;
24 import java.util.ArrayList;
25 import java.util.Arrays;
26 import java.util.List;
29 import java.util.stream.Collectors;
30 import org.eclipse.jdt.annotation.Nullable;
31 import org.onap.ccsdk.features.sdnr.wt.dataprovider.database.sqldb.data.PropertyList;
32 import org.onap.ccsdk.features.sdnr.wt.dataprovider.database.sqldb.database.SqlDBMapper;
33 import org.onap.ccsdk.features.sdnr.wt.dataprovider.database.sqldb.query.filters.SqlDBSearchFilter;
34 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.EntityInput;
35 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.SortOrder;
36 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.entity.input.Filter;
37 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.entity.input.FilterBuilder;
38 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.entity.input.FilterKey;
39 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.entity.input.Pagination;
40 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.entity.input.Sortorder;
41 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.entity.input.SortorderKey;
42 import org.slf4j.Logger;
43 import org.slf4j.LoggerFactory;
45 public class SelectQuery implements SqlQuery {
47 private static final Logger LOG = LoggerFactory.getLogger(SelectQuery.class);
49 private static final long DEFAULT_PAGESIZE = 20;
50 private static final long DEFAULT_PAGE = 1;
51 private final String tableName;
52 private final List<Filter> filters;
53 private final List<String> sortExpressions;
54 private final String controllerId;
56 private long pageSize;
57 private final List<String> fields;
58 private final List<String> groups;
59 private SqlDBSearchFilter allPropertyFilter;
61 public SelectQuery(String tableName) {
62 this(tableName, (String)null);
64 public SelectQuery(String tableName, String controllerId) {
65 this(tableName, Arrays.asList("*"), controllerId);
67 public SelectQuery(String tableName, List<String> fields, String controllerId) {
68 this.tableName = tableName;
70 this.filters = new ArrayList<>();
71 this.sortExpressions = new ArrayList<>();
72 this.groups = new ArrayList<>();
73 this.page = DEFAULT_PAGE;
74 this.pageSize = DEFAULT_PAGESIZE;
75 this.controllerId = controllerId;
76 this.allPropertyFilter = null;
77 if (controllerId != null) {
78 this.addFilter(SqlDBMapper.ODLID_DBCOL, controllerId);
82 public SelectQuery(String tableName, String field, String controllerId) {
83 this(tableName, Arrays.asList(field), controllerId);
86 public SelectQuery(String tableName, EntityInput input) {
87 this(tableName, input, null);
90 public SelectQuery(String tableName, EntityInput input, String controllerId) {
92 Map<FilterKey, Filter> filter = input != null ? input.getFilter() : null;
93 if (filter != null && filter.size() > 0) {
94 for (Filter f : filter.values()) {
98 if (controllerId != null) {
99 this.addFilter(SqlDBMapper.ODLID_DBCOL, controllerId);
102 Map<SortorderKey, Sortorder> so = input != null ? input.getSortorder() : null;
103 if (so != null && !so.isEmpty()) {
104 for (Sortorder s : so.values()) {
105 this.addSortOrder(s.getProperty(), s.getSortorder() == SortOrder.Ascending ? "ASC" : "DESC");
108 Pagination pagination = input != null ? input.getPagination() : null;
109 if (pagination != null) {
110 this.setPagination(pagination.getPage().longValue(), pagination.getSize().longValue());
112 this.setPagination(1, 30);
117 public SelectQuery addFilter(String property, String filtervalue) {
118 this.addFilter(new FilterBuilder().setProperty(property).setFiltervalue(filtervalue).build());
122 private static Filter cleanFilter(Filter filter) {
123 final String sFilter = filter.getFiltervalue();
124 final Set<String> sFilters = filter.getFiltervalues();
125 //if only single filter value is set
126 if (sFilter != null && (sFilters == null || sFilter.isEmpty())) {
127 return "*".equals(filter.getFiltervalue()) ? null : filter;
129 List<String> list = new ArrayList<>(filter.getFiltervalues());
130 if (sFilter != null && !sFilter.isEmpty()) {
133 if (list.size() == 1 && "*".equals(list.get(0))) {
136 return new FilterBuilder().setProperty(filter.getProperty()).setFiltervalue(filter.getFiltervalue())
138 filter.getFiltervalues().stream().filter(e -> !"*".equals(e)).collect(Collectors.toSet()))
143 public void addFilter(Filter filter) {
144 Filter tmp = cleanFilter(filter);
146 LOG.debug("ignore unneccessary filter for {}", filter);
148 this.filters.add(tmp);
152 public void addSortOrder(String col, String order) {
153 this.sortExpressions.add(String.format("`%s` %s", col, order));
155 public void setAllPropertyFilter(String filter, PropertyList propertyList) {
156 this.allPropertyFilter = new SqlDBSearchFilter(propertyList, filter);
158 public void setPagination(long page, long pageSize) {
160 this.pageSize = pageSize;
163 public void setPagination(@Nullable Pagination pagination) {
164 long page = DEFAULT_PAGE;
165 long pageSize = DEFAULT_PAGESIZE;
166 if (pagination != null) {
167 if (pagination.getPage() != null) {
168 page = pagination.getPage().longValue();
170 if (pagination.getSize() != null) {
171 pageSize = pagination.getSize().longValue();
174 this.setPagination(page, pageSize);
179 public String toSql() {
180 StringBuilder sb = new StringBuilder();
181 if (this.fields.size() == 1 && this.fields.contains("*")) {
182 sb.append(String.format("SELECT * FROM `%s`", this.tableName));
184 sb.append(String.format("SELECT `%s` FROM `%s`", String.join("`,`", this.fields), this.tableName));
186 sb.append(SqlQuery.getWhereExpression(this.filters, this.controllerId, this.allPropertyFilter));
187 if (this.groups.size() > 0) {
188 sb.append(String.format(" GROUP BY `%s`", String.join("`,`", this.groups)));
190 if (this.sortExpressions.size() > 0) {
191 sb.append(" ORDER BY " + String.join(",", this.sortExpressions));
193 sb.append(String.format(" LIMIT %d,%d;", (this.page - 1) * this.pageSize, this.pageSize));
194 return sb.toString();
197 public long getPage() {
201 public long getPageSize() {
202 return this.pageSize;
205 public SelectQuery groupBy(String group) {
206 this.groups.add(group);
210 public String toString() {
211 StringBuilder builder = new StringBuilder();
212 builder.append("SelectQuery [tableName=");
213 builder.append(tableName);
214 builder.append(", filters=");
215 builder.append(filters);
216 builder.append(", sortExpressions=");
217 builder.append(sortExpressions);
218 builder.append(", page=");
219 builder.append(page);
220 builder.append(", pageSize=");
221 builder.append(pageSize);
222 builder.append(", fields=");
223 builder.append(fields);
224 builder.append(", groups=");
225 builder.append(groups);
227 return builder.toString();