package eu.eudat.query; import eu.eudat.authorization.AuthorizationFlags; import eu.eudat.commons.enums.IsActive; import eu.eudat.commons.enums.TenantConfigurationType; import eu.eudat.data.TenantConfigurationEntity; import eu.eudat.model.tenantconfiguration.TenantConfiguration; import gr.cite.tools.data.query.FieldResolver; import gr.cite.tools.data.query.QueryBase; import gr.cite.tools.data.query.QueryContext; import jakarta.persistence.Tuple; import jakarta.persistence.criteria.CriteriaBuilder; import jakarta.persistence.criteria.Predicate; import org.springframework.beans.factory.config.ConfigurableBeanFactory; import org.springframework.context.annotation.Scope; import org.springframework.stereotype.Component; import java.time.Instant; import java.util.*; @Component @Scope(value = ConfigurableBeanFactory.SCOPE_PROTOTYPE) public class TenantConfigurationQuery extends QueryBase { private Collection ids; private Collection tenantIds; private Boolean tenantIsSet; private Collection isActives; private Collection types; private Collection excludedIds; private EnumSet authorize = EnumSet.of(AuthorizationFlags.None); public TenantConfigurationQuery() { } public TenantConfigurationQuery ids(UUID value) { this.ids = List.of(value); return this; } public TenantConfigurationQuery ids(UUID... value) { this.ids = Arrays.asList(value); return this; } public TenantConfigurationQuery ids(Collection values) { this.ids = values; return this; } public TenantConfigurationQuery tenantIds(UUID value) { this.tenantIds = List.of(value); return this; } public TenantConfigurationQuery tenantIds(UUID... value) { this.tenantIds = Arrays.asList(value); return this; } public TenantConfigurationQuery tenantIds(Collection values) { this.tenantIds = values; return this; } public TenantConfigurationQuery tenantIsSet(Boolean values) { this.tenantIsSet = values; return this; } public TenantConfigurationQuery isActive(IsActive value) { this.isActives = List.of(value); return this; } public TenantConfigurationQuery isActive(IsActive... value) { this.isActives = Arrays.asList(value); return this; } public TenantConfigurationQuery isActive(Collection values) { this.isActives = values; return this; } public TenantConfigurationQuery types(TenantConfigurationType value) { this.types = List.of(value); return this; } public TenantConfigurationQuery types(TenantConfigurationType... value) { this.types = Arrays.asList(value); return this; } public TenantConfigurationQuery types(Collection values) { this.types = values; return this; } public TenantConfigurationQuery excludedIds(Collection values) { this.excludedIds = values; return this; } public TenantConfigurationQuery excludedIds(UUID value) { this.excludedIds = List.of(value); return this; } public TenantConfigurationQuery excludedIds(UUID... value) { this.excludedIds = Arrays.asList(value); return this; } public TenantConfigurationQuery authorize(EnumSet values) { this.authorize = values; return this; } @Override protected Boolean isFalseQuery() { return this.isEmpty(this.ids) ||this.isEmpty(this.isActives) ||this.isEmpty(this.types) || this.isEmpty(this.tenantIds); } @Override protected Class entityClass() { return TenantConfigurationEntity.class; } @Override protected Predicate applyFilters(QueryContext queryContext) { List predicates = new ArrayList<>(); if (this.ids != null) { CriteriaBuilder.In inClause = queryContext.CriteriaBuilder.in(queryContext.Root.get(TenantConfigurationEntity._id)); for (UUID item : this.ids) inClause.value(item); predicates.add(inClause); } if (this.tenantIds != null) { CriteriaBuilder.In inClause = queryContext.CriteriaBuilder.in(queryContext.Root.get(TenantConfigurationEntity._tenantId)); for (UUID item : this.tenantIds) inClause.value(item); predicates.add(inClause); } if (this.isActives != null) { CriteriaBuilder.In inClause = queryContext.CriteriaBuilder.in(queryContext.Root.get(TenantConfigurationEntity._isActive)); for (IsActive item : this.isActives) inClause.value(item); predicates.add(inClause); } if (this.tenantIsSet != null) { if (this.tenantIsSet) predicates.add(queryContext.CriteriaBuilder.isNotNull(queryContext.Root.get(TenantConfigurationEntity._tenantId))); else predicates.add(queryContext.CriteriaBuilder.isNull(queryContext.Root.get(TenantConfigurationEntity._tenantId))); } if (this.types != null) { CriteriaBuilder.In inClause = queryContext.CriteriaBuilder.in(queryContext.Root.get(TenantConfigurationEntity._type)); for (TenantConfigurationType item : this.types) inClause.value(item); predicates.add(inClause); } if (this.excludedIds != null) { CriteriaBuilder.In notInClause = queryContext.CriteriaBuilder.in(queryContext.Root.get(TenantConfigurationEntity._id)); for (UUID item : this.excludedIds) notInClause.value(item); predicates.add(notInClause.not()); } if (!predicates.isEmpty()) { Predicate[] predicatesArray = predicates.toArray(new Predicate[0]); return queryContext.CriteriaBuilder.and(predicatesArray); } else { return null; } } @Override protected TenantConfigurationEntity convert(Tuple tuple, Set columns) { TenantConfigurationEntity item = new TenantConfigurationEntity(); item.setId(QueryBase.convertSafe(tuple, columns, TenantConfigurationEntity._id, UUID.class)); item.setValue(QueryBase.convertSafe(tuple, columns, TenantConfigurationEntity._value, String.class)); item.setTenantId(QueryBase.convertSafe(tuple, columns, TenantConfigurationEntity._tenantId, UUID.class)); item.setType(QueryBase.convertSafe(tuple, columns, TenantConfigurationEntity._type, TenantConfigurationType.class)); item.setCreatedAt(QueryBase.convertSafe(tuple, columns, TenantConfigurationEntity._createdAt, Instant.class)); item.setUpdatedAt(QueryBase.convertSafe(tuple, columns, TenantConfigurationEntity._updatedAt, Instant.class)); item.setIsActive(QueryBase.convertSafe(tuple, columns, TenantConfigurationEntity._isActive, IsActive.class)); return item; } @Override protected String fieldNameOf(FieldResolver item) { if (item.match(TenantConfiguration._id)) return TenantConfigurationEntity._id; else if (item.match(TenantConfiguration._type)) return TenantConfigurationEntity._type; else if (item.prefix(TenantConfiguration._cssColors)) return TenantConfigurationEntity._value; else if (item.match(TenantConfiguration._cssColors)) return TenantConfigurationEntity._value; else if (item.prefix(TenantConfiguration._depositPlugins)) return TenantConfigurationEntity._value; else if (item.match(TenantConfiguration._depositPlugins)) return TenantConfigurationEntity._value; else if (item.prefix(TenantConfiguration._defaultUserLocale)) return TenantConfigurationEntity._value; else if (item.match(TenantConfiguration._defaultUserLocale)) return TenantConfigurationEntity._value; else if (item.prefix(TenantConfiguration._fileTransformerPlugins)) return TenantConfigurationEntity._value; else if (item.match(TenantConfiguration._fileTransformerPlugins)) return TenantConfigurationEntity._value; else if (item.prefix(TenantConfiguration._logo)) return TenantConfigurationEntity._value; else if (item.match(TenantConfiguration._logo)) return TenantConfigurationEntity._value; else if (item.match(TenantConfiguration._createdAt)) return TenantConfigurationEntity._createdAt; else if (item.match(TenantConfiguration._updatedAt)) return TenantConfigurationEntity._updatedAt; else if (item.match(TenantConfiguration._isActive)) return TenantConfigurationEntity._isActive; else if (item.match(TenantConfiguration._belongsToCurrentTenant)) return TenantConfigurationEntity._tenantId; else if (item.match(TenantConfigurationEntity._tenantId)) return TenantConfigurationEntity._tenantId; else return null; } }