2023-10-27 10:59:37 +02:00
|
|
|
package eu.eudat.model.builder;
|
|
|
|
|
|
|
|
import eu.eudat.authorization.AuthorizationFlags;
|
2024-02-06 11:27:47 +01:00
|
|
|
import eu.eudat.commons.JsonHandlingService;
|
|
|
|
import eu.eudat.commons.types.descriptionreference.DescriptionReferenceDataEntity;
|
|
|
|
import eu.eudat.commons.types.dmpreference.DmpReferenceDataEntity;
|
2023-10-27 10:59:37 +02:00
|
|
|
import eu.eudat.convention.ConventionService;
|
|
|
|
import eu.eudat.data.DescriptionReferenceEntity;
|
|
|
|
import eu.eudat.model.Description;
|
|
|
|
import eu.eudat.model.DescriptionReference;
|
2024-02-06 11:27:47 +01:00
|
|
|
import eu.eudat.model.DmpReference;
|
2023-10-27 10:59:37 +02:00
|
|
|
import eu.eudat.model.Reference;
|
2024-02-06 11:27:47 +01:00
|
|
|
import eu.eudat.model.builder.descriptionreference.DescriptionReferenceDataBuilder;
|
|
|
|
import eu.eudat.model.builder.dmpreference.DmpReferenceDataBuilder;
|
2023-10-27 10:59:37 +02:00
|
|
|
import eu.eudat.query.DescriptionQuery;
|
|
|
|
import eu.eudat.query.ReferenceQuery;
|
|
|
|
import gr.cite.tools.data.builder.BuilderFactory;
|
|
|
|
import gr.cite.tools.data.query.QueryFactory;
|
|
|
|
import gr.cite.tools.exception.MyApplicationException;
|
|
|
|
import gr.cite.tools.fieldset.BaseFieldSet;
|
|
|
|
import gr.cite.tools.fieldset.FieldSet;
|
|
|
|
import gr.cite.tools.logging.DataLogEntry;
|
|
|
|
import gr.cite.tools.logging.LoggerService;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
import org.springframework.beans.factory.config.ConfigurableBeanFactory;
|
|
|
|
import org.springframework.context.annotation.Scope;
|
|
|
|
import org.springframework.stereotype.Component;
|
|
|
|
|
|
|
|
import java.util.*;
|
|
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
|
|
@Component
|
|
|
|
@Scope(value = ConfigurableBeanFactory.SCOPE_PROTOTYPE)
|
|
|
|
public class DescriptionReferenceBuilder extends BaseBuilder<DescriptionReference, DescriptionReferenceEntity> {
|
|
|
|
|
|
|
|
private final BuilderFactory builderFactory;
|
|
|
|
|
|
|
|
private final QueryFactory queryFactory;
|
|
|
|
|
|
|
|
private EnumSet<AuthorizationFlags> authorize = EnumSet.of(AuthorizationFlags.None);
|
2024-02-06 11:27:47 +01:00
|
|
|
private final JsonHandlingService jsonHandlingService;
|
2023-10-27 10:59:37 +02:00
|
|
|
|
|
|
|
@Autowired
|
|
|
|
public DescriptionReferenceBuilder(
|
2024-02-06 11:27:47 +01:00
|
|
|
ConventionService conventionService,
|
|
|
|
BuilderFactory builderFactory, QueryFactory queryFactory, JsonHandlingService jsonHandlingService) {
|
2023-11-06 12:31:01 +01:00
|
|
|
super(conventionService, new LoggerService(LoggerFactory.getLogger(DescriptionReferenceBuilder.class)));
|
2023-10-27 10:59:37 +02:00
|
|
|
this.builderFactory = builderFactory;
|
|
|
|
this.queryFactory = queryFactory;
|
2024-02-06 11:27:47 +01:00
|
|
|
this.jsonHandlingService = jsonHandlingService;
|
2023-10-27 10:59:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public DescriptionReferenceBuilder authorize(EnumSet<AuthorizationFlags> values) {
|
|
|
|
this.authorize = values;
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public List<DescriptionReference> build(FieldSet fields, List<DescriptionReferenceEntity> data) throws MyApplicationException {
|
|
|
|
this.logger.debug("building for {} items requesting {} fields", Optional.ofNullable(data).map(List::size).orElse(0), Optional.ofNullable(fields).map(FieldSet::getFields).map(Set::size).orElse(0));
|
|
|
|
this.logger.trace(new DataLogEntry("requested fields", fields));
|
|
|
|
if (fields == null || data == null || fields.isEmpty())
|
|
|
|
return new ArrayList<>();
|
|
|
|
|
|
|
|
FieldSet referenceFields = fields.extractPrefixed(this.asPrefix(DescriptionReference._reference));
|
|
|
|
Map<UUID, Reference> referenceItemsMap = this.collectReferences(referenceFields, data);
|
|
|
|
|
|
|
|
FieldSet descriptionFields = fields.extractPrefixed(this.asPrefix(DescriptionReference._description));
|
|
|
|
Map<UUID, Description> descriptionItemsMap = this.collectDescriptions(descriptionFields, data);
|
2024-02-06 11:27:47 +01:00
|
|
|
|
|
|
|
FieldSet dataFields = fields.extractPrefixed(this.asPrefix(DescriptionReference._data));
|
2023-10-27 10:59:37 +02:00
|
|
|
|
|
|
|
List<DescriptionReference> models = new ArrayList<>();
|
|
|
|
for (DescriptionReferenceEntity d : data) {
|
|
|
|
DescriptionReference m = new DescriptionReference();
|
2023-11-20 16:09:24 +01:00
|
|
|
if (fields.hasField(this.asIndexer(DescriptionReference._id))) m.setId(d.getId());
|
|
|
|
if (fields.hasField(this.asIndexer(DescriptionReference._createdAt))) m.setCreatedAt(d.getCreatedAt());
|
|
|
|
if (fields.hasField(this.asIndexer(DescriptionReference._updatedAt))) m.setUpdatedAt(d.getUpdatedAt());
|
|
|
|
if (fields.hasField(this.asIndexer(DescriptionReference._hash))) m.setHash(this.hashValue(d.getUpdatedAt()));
|
|
|
|
if (fields.hasField(this.asIndexer(DescriptionReference._isActive))) m.setIsActive(d.getIsActive());
|
|
|
|
if (!referenceFields.isEmpty() && referenceItemsMap != null && referenceItemsMap.containsKey(d.getReferenceId())) m.setReference(referenceItemsMap.get(d.getReferenceId()));
|
|
|
|
if (!descriptionFields.isEmpty() && descriptionItemsMap != null && descriptionItemsMap.containsKey(d.getDescriptionId())) m.setDescription(descriptionItemsMap.get(d.getDescriptionId()));
|
2024-02-06 11:27:47 +01:00
|
|
|
if (!dataFields.isEmpty() && d.getData() != null){
|
|
|
|
DescriptionReferenceDataEntity propertyDefinition = this.jsonHandlingService.fromJsonSafe(DescriptionReferenceDataEntity.class, d.getData());
|
|
|
|
m.setData(this.builderFactory.builder(DescriptionReferenceDataBuilder.class).authorize(this.authorize).build(dataFields, propertyDefinition));
|
|
|
|
}
|
2023-10-27 10:59:37 +02:00
|
|
|
models.add(m);
|
|
|
|
}
|
|
|
|
|
|
|
|
this.logger.debug("build {} items", Optional.of(models).map(List::size).orElse(0));
|
|
|
|
|
|
|
|
return models;
|
|
|
|
}
|
|
|
|
|
|
|
|
private Map<UUID, Description> collectDescriptions(FieldSet fields, List<DescriptionReferenceEntity> data) throws MyApplicationException {
|
|
|
|
if (fields.isEmpty() || data.isEmpty())
|
|
|
|
return null;
|
|
|
|
this.logger.debug("checking related - {}", Description.class.getSimpleName());
|
|
|
|
|
|
|
|
Map<UUID, Description> itemMap;
|
|
|
|
if (!fields.hasOtherField(this.asIndexer(Reference._id))) {
|
|
|
|
itemMap = this.asEmpty(
|
|
|
|
data.stream().map(DescriptionReferenceEntity::getDescriptionId).distinct().collect(Collectors.toList()),
|
|
|
|
x -> {
|
|
|
|
Description item = new Description();
|
|
|
|
item.setId(x);
|
|
|
|
return item;
|
|
|
|
},
|
|
|
|
Description::getId);
|
|
|
|
} else {
|
|
|
|
FieldSet clone = new BaseFieldSet(fields.getFields()).ensure(Reference._id);
|
|
|
|
DescriptionQuery q = this.queryFactory.query(DescriptionQuery.class).authorize(this.authorize).ids(data.stream().map(DescriptionReferenceEntity::getDescriptionId).distinct().collect(Collectors.toList()));
|
|
|
|
itemMap = this.builderFactory.builder(DescriptionBuilder.class).authorize(this.authorize).asForeignKey(q, clone, Description::getId);
|
|
|
|
}
|
|
|
|
if (!fields.hasField(Description._id)) {
|
|
|
|
itemMap.forEach((id, item) -> {
|
|
|
|
if (item != null)
|
|
|
|
item.setId(null);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
return itemMap;
|
|
|
|
}
|
|
|
|
|
|
|
|
private Map<UUID, Reference> collectReferences(FieldSet fields, List<DescriptionReferenceEntity> data) throws MyApplicationException {
|
|
|
|
if (fields.isEmpty() || data.isEmpty())
|
|
|
|
return null;
|
|
|
|
this.logger.debug("checking related - {}", Reference.class.getSimpleName());
|
|
|
|
|
|
|
|
Map<UUID, Reference> itemMap;
|
|
|
|
if (!fields.hasOtherField(this.asIndexer(Reference._id))) {
|
|
|
|
itemMap = this.asEmpty(
|
|
|
|
data.stream().map(DescriptionReferenceEntity::getReferenceId).distinct().collect(Collectors.toList()),
|
|
|
|
x -> {
|
|
|
|
Reference item = new Reference();
|
|
|
|
item.setId(x);
|
|
|
|
return item;
|
|
|
|
},
|
|
|
|
Reference::getId);
|
|
|
|
} else {
|
|
|
|
FieldSet clone = new BaseFieldSet(fields.getFields()).ensure(Reference._id);
|
|
|
|
ReferenceQuery q = this.queryFactory.query(ReferenceQuery.class).authorize(this.authorize).ids(data.stream().map(DescriptionReferenceEntity::getReferenceId).distinct().collect(Collectors.toList()));
|
|
|
|
itemMap = this.builderFactory.builder(ReferenceBuilder.class).authorize(this.authorize).asForeignKey(q, clone, Reference::getId);
|
|
|
|
}
|
|
|
|
if (!fields.hasField(Reference._id)) {
|
|
|
|
itemMap.forEach((id, item) -> {
|
|
|
|
if (item != null)
|
|
|
|
item.setId(null);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
return itemMap;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|