2023-12-13 10:42:59 +01:00
|
|
|
package eu.eudat.model.censorship.deposit;
|
|
|
|
|
|
|
|
import eu.eudat.authorization.Permission;
|
|
|
|
import eu.eudat.convention.ConventionService;
|
|
|
|
import eu.eudat.model.Description;
|
|
|
|
import eu.eudat.model.censorship.*;
|
|
|
|
import eu.eudat.model.censorship.descriptionproperties.PropertyDefinitionCensor;
|
|
|
|
import gr.cite.commons.web.authz.service.AuthorizationService;
|
|
|
|
import gr.cite.tools.data.censor.CensorFactory;
|
|
|
|
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.config.ConfigurableBeanFactory;
|
|
|
|
import org.springframework.context.annotation.Scope;
|
|
|
|
import org.springframework.stereotype.Component;
|
|
|
|
|
|
|
|
import java.util.UUID;
|
|
|
|
|
|
|
|
@Component
|
|
|
|
@Scope(value = ConfigurableBeanFactory.SCOPE_PROTOTYPE)
|
|
|
|
public class DepositConfigurationCensor extends BaseCensor {
|
|
|
|
|
|
|
|
private static final LoggerService logger = new LoggerService(LoggerFactory.getLogger(DepositConfigurationCensor.class));
|
|
|
|
|
|
|
|
protected final AuthorizationService authService;
|
|
|
|
|
|
|
|
|
|
|
|
public DepositConfigurationCensor(ConventionService conventionService, AuthorizationService authService) {
|
|
|
|
super(conventionService);
|
|
|
|
this.authService = authService;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void censor(FieldSet fields, UUID userId) {
|
|
|
|
logger.debug(new DataLogEntry("censoring fields", fields));
|
|
|
|
if (fields == null || fields.isEmpty())
|
|
|
|
return;
|
|
|
|
|
2024-03-27 13:57:02 +01:00
|
|
|
this.authService.authorizeForce(Permission.BrowseDeposit, Permission.DeferredAffiliation);
|
2023-12-13 10:42:59 +01:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|