Search in sources :

Example 1 with SERVER_INFORMATION

use of org.finos.waltz.schema.Tables.SERVER_INFORMATION in project waltz by khartec.

the class MariaServerInformationSearch method searchFullText.

@Override
public List<ServerInformation> searchFullText(DSLContext dsl, EntitySearchOptions options) {
    List<String> terms = SearchUtilities.mkTerms(options.searchQuery());
    if (terms.isEmpty()) {
        return Collections.emptyList();
    }
    Condition externalIdCondition = terms.stream().map(term -> SERVER_INFORMATION.EXTERNAL_ID.like(term + "%")).collect(Collectors.reducing(DSL.trueCondition(), (acc, frag) -> acc.and(frag)));
    List<ServerInformation> serversViaExternalId = dsl.selectDistinct(SERVER_INFORMATION.fields()).from(SERVER_INFORMATION).where(externalIdCondition).orderBy(SERVER_INFORMATION.HOSTNAME).limit(options.limit()).fetch(ServerInformationDao.TO_DOMAIN_MAPPER);
    Condition hostnameCondition = terms.stream().map(term -> SERVER_INFORMATION.HOSTNAME.like("%" + term + "%")).collect(Collectors.reducing(DSL.trueCondition(), (acc, frag) -> acc.and(frag)));
    List<ServerInformation> serversViaHostname = dsl.selectDistinct(SERVER_INFORMATION.fields()).from(SERVER_INFORMATION).where(hostnameCondition).orderBy(SERVER_INFORMATION.HOSTNAME).limit(options.limit()).fetch(ServerInformationDao.TO_DOMAIN_MAPPER);
    List<ServerInformation> serversViaFullText = dsl.select(SERVER_INFORMATION.fields()).from(SERVER_INFORMATION).where("MATCH(hostname, external_id, operating_system, location) AGAINST (?)", options.searchQuery()).limit(options.limit()).fetch(ServerInformationDao.TO_DOMAIN_MAPPER);
    serversViaHostname.sort(SearchUtilities.mkRelevancyComparator(a -> a.hostname(), terms.get(0)));
    serversViaExternalId.sort(SearchUtilities.mkRelevancyComparator(a -> a.externalId().orElse(null), terms.get(0)));
    return new ArrayList<>(orderedUnion(serversViaExternalId, serversViaHostname, serversViaFullText));
}
Also used : Condition(org.jooq.Condition) SERVER_INFORMATION(org.finos.waltz.schema.Tables.SERVER_INFORMATION) DSL(org.jooq.impl.DSL) DatabaseVendorSpecific(org.finos.waltz.data.DatabaseVendorSpecific) ServerInformationDao(org.finos.waltz.data.server_information.ServerInformationDao) SearchUtilities(org.finos.waltz.data.SearchUtilities) Collectors(java.util.stream.Collectors) EntitySearchOptions(org.finos.waltz.model.entity_search.EntitySearchOptions) Condition(org.jooq.Condition) ArrayList(java.util.ArrayList) List(java.util.List) ServerInformation(org.finos.waltz.model.server_information.ServerInformation) FullTextSearch(org.finos.waltz.data.FullTextSearch) DSLContext(org.jooq.DSLContext) Collections(java.util.Collections) SetUtilities.orderedUnion(org.finos.waltz.common.SetUtilities.orderedUnion) ServerInformation(org.finos.waltz.model.server_information.ServerInformation) ArrayList(java.util.ArrayList)

Example 2 with SERVER_INFORMATION

use of org.finos.waltz.schema.Tables.SERVER_INFORMATION in project waltz by khartec.

the class ServerInformationSearchDao method search.

@Override
public List<ServerInformation> search(EntitySearchOptions options) {
    checkNotNull(options, "options cannot be null");
    List<String> terms = SearchUtilities.mkTerms(options.searchQuery());
    if (terms.isEmpty()) {
        return Collections.emptyList();
    }
    Condition externalIdCondition = JooqUtilities.mkStartsWithTermSearch(SERVER_INFORMATION.EXTERNAL_ID, terms);
    List<ServerInformation> serversViaExternalId = dsl.select(SERVER_INFORMATION.fields()).from(SERVER_INFORMATION).where(externalIdCondition).orderBy(SERVER_INFORMATION.HOSTNAME).limit(options.limit()).fetch(ServerInformationDao.TO_DOMAIN_MAPPER);
    Condition hostnameCondition = JooqUtilities.mkBasicTermSearch(SERVER_INFORMATION.HOSTNAME, terms);
    List<ServerInformation> serversViaHostname = dsl.select(SERVER_INFORMATION.fields()).from(SERVER_INFORMATION).where(hostnameCondition).orderBy(SERVER_INFORMATION.HOSTNAME).limit(options.limit()).fetch(ServerInformationDao.TO_DOMAIN_MAPPER);
    List<ServerInformation> serversViaFullText = searcher.searchFullText(dsl, options);
    serversViaHostname.sort(SearchUtilities.mkRelevancyComparator(ServerInformation::hostname, terms.get(0)));
    serversViaExternalId.sort(SearchUtilities.mkRelevancyComparator(a -> a.externalId().orElse(null), terms.get(0)));
    return new ArrayList<>(orderedUnion(serversViaExternalId, serversViaHostname, serversViaFullText));
}
Also used : Condition(org.jooq.Condition) SERVER_INFORMATION(org.finos.waltz.schema.Tables.SERVER_INFORMATION) Autowired(org.springframework.beans.factory.annotation.Autowired) ServerInformationDao(org.finos.waltz.data.server_information.ServerInformationDao) EntitySearchOptions(org.finos.waltz.model.entity_search.EntitySearchOptions) Condition(org.jooq.Condition) ArrayList(java.util.ArrayList) List(java.util.List) Checks.checkNotNull(org.finos.waltz.common.Checks.checkNotNull) org.finos.waltz.data(org.finos.waltz.data) ServerInformation(org.finos.waltz.model.server_information.ServerInformation) DSLContext(org.jooq.DSLContext) SQLDialect(org.jooq.SQLDialect) Repository(org.springframework.stereotype.Repository) Collections(java.util.Collections) SetUtilities.orderedUnion(org.finos.waltz.common.SetUtilities.orderedUnion) ServerInformation(org.finos.waltz.model.server_information.ServerInformation) ArrayList(java.util.ArrayList)

Aggregations

ArrayList (java.util.ArrayList)2 Collections (java.util.Collections)2 List (java.util.List)2 SetUtilities.orderedUnion (org.finos.waltz.common.SetUtilities.orderedUnion)2 ServerInformationDao (org.finos.waltz.data.server_information.ServerInformationDao)2 EntitySearchOptions (org.finos.waltz.model.entity_search.EntitySearchOptions)2 ServerInformation (org.finos.waltz.model.server_information.ServerInformation)2 SERVER_INFORMATION (org.finos.waltz.schema.Tables.SERVER_INFORMATION)2 Condition (org.jooq.Condition)2 DSLContext (org.jooq.DSLContext)2 Collectors (java.util.stream.Collectors)1 Checks.checkNotNull (org.finos.waltz.common.Checks.checkNotNull)1 org.finos.waltz.data (org.finos.waltz.data)1 DatabaseVendorSpecific (org.finos.waltz.data.DatabaseVendorSpecific)1 FullTextSearch (org.finos.waltz.data.FullTextSearch)1 SearchUtilities (org.finos.waltz.data.SearchUtilities)1 SQLDialect (org.jooq.SQLDialect)1 DSL (org.jooq.impl.DSL)1 Autowired (org.springframework.beans.factory.annotation.Autowired)1 Repository (org.springframework.stereotype.Repository)1