All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.wavemaker.runtime.data.dao.query.providers.RuntimeQueryProvider Maven / Gradle / Ivy

The newest version!
/*******************************************************************************
 * Copyright (C) 2022-2023 WaveMaker, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 ******************************************************************************/
package com.wavemaker.runtime.data.dao.query.providers;

import java.util.Optional;

import org.apache.commons.lang3.StringUtils;
import org.hibernate.Session;
import org.hibernate.engine.spi.SessionFactoryImplementor;
import org.hibernate.query.Query;
import org.springframework.data.domain.Pageable;

import com.wavemaker.runtime.data.dao.util.QueryHelper;
import com.wavemaker.runtime.data.filter.WMQueryInfo;
import com.wavemaker.runtime.data.model.queries.RuntimeQuery;
import com.wavemaker.runtime.data.transform.Transformers;
import com.wavemaker.runtime.data.transform.WMResultTransformer;

/**
 * @author Dilip Kumar
 * @since 4/8/17
 */
public class RuntimeQueryProvider implements QueryProvider, PaginatedQueryProvider {

    private final String queryString;
    private final String countQueryString;

    private final boolean nativeSql;

    private final Class responseType;

    private RuntimeQueryProvider(final Builder builder) {
        queryString = builder.queryString;
        countQueryString = builder.countQueryString;
        nativeSql = builder.nativeSql;
        responseType = builder.responseType;
    }

    public static  RuntimeQueryProvider from(RuntimeQuery query, Class returnType) {
        String countQueryString = query.getCountQueryString();

        if (StringUtils.isBlank(countQueryString)) {
            countQueryString = QueryHelper.getCountQuery(query.getQueryString(), query.isNativeSql());
        }

        return RuntimeQueryProvider.newBuilder(returnType)
            .withQueryString(query.getQueryString())
            .withCountQueryString(countQueryString)
            .withNativeSql(query.isNativeSql())
            .build();
    }

    public static  RuntimeQueryProvider from(WMQueryInfo queryInfo, Class returnType) {
        String countQuery = QueryHelper.getCountQuery(queryInfo.getQuery(), false);

        return RuntimeQueryProvider.newBuilder(returnType)
            .withQueryString(queryInfo.getQuery())
            .withCountQueryString(countQuery)
            .withNativeSql(false)
            .build();
    }

    public static  Builder newBuilder(Class responseType) {
        return new Builder<>(responseType);
    }

    @Override
    public Query getQuery(final Session session, final Pageable pageable) {
        String sortedQuery = queryString;

        if (pageable.getSort().isSorted()) {
            final WMResultTransformer transformer = Transformers.aliasToMappedClass(responseType);
            if (nativeSql) {
                sortedQuery = QueryHelper.applySortingForNativeQuery(queryString, pageable.getSort(),
                    transformer, ((SessionFactoryImplementor) session.getSessionFactory()).getDialect());
            } else {
                sortedQuery = QueryHelper.applySortingForHqlQuery(queryString, pageable.getSort(), transformer);
            }
        }

        Query hibernateQuery = createQuery(session, sortedQuery, responseType);

        if (!pageable.isUnpaged()) {
            hibernateQuery.setFirstResult((int) pageable.getOffset());
            hibernateQuery.setMaxResults(pageable.getPageSize());
        }

        return hibernateQuery;
    }

    @Override
    public Optional> getCountQuery(final Session session) {
        if (StringUtils.isNotBlank(countQueryString)) {
            return Optional.of(createQuery(session, countQueryString, Number.class));
        } else {
            return Optional.empty();
        }
    }

    @Override
    public Query getQuery(final Session session) {
        return createQuery(session, queryString, responseType);
    }

    @SuppressWarnings("unchecked")
    private  Query createQuery(final Session session, String queryString, final Class returnType) {
        final Query hibernateQuery;
        if (nativeSql) {
            hibernateQuery = session.createNativeQuery(queryString);
            Transformers.aliasToMappedClassOptional(returnType).ifPresent(hibernateQuery::setResultTransformer);
        } else {
            hibernateQuery = session.createQuery(queryString);
            if (hibernateQuery.getReturnAliases() != null && hibernateQuery.getReturnAliases().length != 0) {
                Transformers.aliasToMappedClassOptional(returnType).ifPresent(hibernateQuery::setResultTransformer);
            }
        }

        return hibernateQuery;
    }

    public static final class Builder {
        private String queryString;
        private String countQueryString;
        private boolean nativeSql;
        private Class responseType;

        private Builder(Class responseType) {
            this.responseType = responseType;
        }

        public Builder withQueryString(final String val) {
            queryString = val;
            return this;
        }

        public Builder withCountQueryString(final String val) {
            countQueryString = val;
            return this;
        }

        public Builder withNativeSql(final boolean val) {
            nativeSql = val;
            return this;
        }

        public RuntimeQueryProvider build() {
            return new RuntimeQueryProvider<>(this);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy