package eu.eudat.model.builder.referencetypedefinition; import eu.eudat.authorization.AuthorizationFlags; import eu.eudat.commons.types.referencetype.DependencyPropertyEntity; import eu.eudat.convention.ConventionService; import eu.eudat.model.builder.BaseBuilder; import eu.eudat.model.referencetypedefinition.DependencyProperty; import gr.cite.tools.data.builder.BuilderFactory; import gr.cite.tools.exception.MyApplicationException; 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.*; @Component @Scope(value = ConfigurableBeanFactory.SCOPE_PROTOTYPE) public class DependencyPropertyBuilder extends BaseBuilder { private final BuilderFactory builderFactory; private EnumSet authorize = EnumSet.of(AuthorizationFlags.None); @Autowired public DependencyPropertyBuilder( ConventionService conventionService, BuilderFactory builderFactory) { super(conventionService, new LoggerService(LoggerFactory.getLogger(DependencyPropertyBuilder.class))); this.builderFactory = builderFactory; } public DependencyPropertyBuilder authorize(EnumSet values) { this.authorize = values; return this; } @Override public List build(FieldSet fields, List 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<>(); List models = new ArrayList<>(); for (DependencyPropertyEntity d : data) { DependencyProperty m = new DependencyProperty(); if (fields.hasField(this.asIndexer(DependencyProperty._code))) m.setCode(d.getCode()); if (fields.hasField(this.asIndexer(DependencyProperty._target))) m.setTarget(d.getTarget()); if (fields.hasField(this.asIndexer(DependencyProperty._required))) m.setRequired(d.getRequired()); models.add(m); } this.logger.debug("build {} items", Optional.of(models).map(List::size).orElse(0)); return models; } }