argos/dmp-backend/core/src/main/java/eu/eudat/model/censorship/UserCredentialCensor.java

51 lines
2.1 KiB
Java
Raw Normal View History

2023-11-07 16:07:24 +01:00
package eu.eudat.model.censorship;
2023-11-17 18:01:44 +01:00
import eu.eudat.authorization.OwnedResource;
2023-11-07 16:07:24 +01:00
import eu.eudat.authorization.Permission;
import eu.eudat.convention.ConventionService;
2023-11-17 18:01:44 +01:00
import eu.eudat.model.UserCredential;
2024-01-15 17:03:12 +01:00
import eu.eudat.model.censorship.usercredential.UserCredentialDataCensor;
2023-11-07 16:07:24 +01:00
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;
2023-11-17 18:01:44 +01:00
import java.util.List;
2023-11-07 16:07:24 +01:00
import java.util.UUID;
@Component
@Scope(value = ConfigurableBeanFactory.SCOPE_PROTOTYPE)
2023-11-17 18:01:44 +01:00
public class UserCredentialCensor extends BaseCensor {
2023-11-07 16:07:24 +01:00
2023-11-17 18:01:44 +01:00
private static final LoggerService logger = new LoggerService(LoggerFactory.getLogger(UserCredentialCensor.class));
2023-11-07 16:07:24 +01:00
protected final AuthorizationService authService;
2023-11-17 18:01:44 +01:00
2023-11-07 16:07:24 +01:00
protected final CensorFactory censorFactory;
2023-11-17 18:01:44 +01:00
public UserCredentialCensor(ConventionService conventionService, AuthorizationService authService, CensorFactory censorFactory) {
2023-11-07 16:07:24 +01:00
super(conventionService);
this.authService = authService;
this.censorFactory = censorFactory;
}
2023-11-17 18:01:44 +01:00
public void censor(FieldSet fields, UUID userId) {
2023-11-07 16:07:24 +01:00
logger.debug(new DataLogEntry("censoring fields", fields));
if (fields == null || fields.isEmpty())
return;
2023-11-17 18:01:44 +01:00
this.authService.authorizeAtLeastOneForce(userId != null ? List.of(new OwnedResource(userId)) : null, Permission.BrowseUser);
2023-11-07 16:07:24 +01:00
2023-11-17 18:01:44 +01:00
FieldSet descriptionReferenceFields = fields.extractPrefixed(this.asIndexerPrefix(UserCredential._user));
this.censorFactory.censor(DescriptionReferenceCensor.class).censor(descriptionReferenceFields, userId);
2024-01-15 17:03:12 +01:00
FieldSet dataFields = fields.extractPrefixed(this.asIndexerPrefix(UserCredential._data));
this.censorFactory.censor(UserCredentialDataCensor.class).censor(dataFields, userId);
2023-11-07 16:07:24 +01:00
}
}