com.netgrif.application.engine.elastic.domain.ElasticCase Maven / Gradle / Ivy
package com.netgrif.application.engine.elastic.domain;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.fasterxml.jackson.datatype.jsr310.deser.LocalDateTimeDeserializer;
import com.fasterxml.jackson.datatype.jsr310.ser.LocalDateTimeSerializer;
import com.netgrif.application.engine.workflow.domain.Case;
import com.netgrif.application.engine.workflow.domain.TaskPair;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.springframework.data.annotation.Id;
import org.springframework.data.annotation.Version;
import org.springframework.data.elasticsearch.annotations.DateFormat;
import org.springframework.data.elasticsearch.annotations.Document;
import org.springframework.data.elasticsearch.annotations.Field;
import org.springframework.data.elasticsearch.annotations.FieldType;
import java.sql.Timestamp;
import java.time.LocalDateTime;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
import java.util.stream.Collectors;
import static org.springframework.data.elasticsearch.annotations.FieldType.Keyword;
@Data
@NoArgsConstructor
@AllArgsConstructor
@Document(indexName = "#{@elasticCaseIndex}")
public class ElasticCase {
@Id
private String id;
@Field(type = Keyword)
private String uriNodeId;
@Version
private Long version;
private Long lastModified;
@Field(type = Keyword)
private String stringId;
private String visualId;
@Field(type = Keyword)
private String processIdentifier;
@Field(type = Keyword)
private String processId;
private String title;
@JsonSerialize(using = LocalDateTimeSerializer.class)
@JsonDeserialize(using = LocalDateTimeDeserializer.class)
@Field(type = FieldType.Date, format = DateFormat.date_hour_minute_second_millis)
private LocalDateTime creationDate;
private Long creationDateSortable;
@Field(type = Keyword)
private String author;
@Field(type = Keyword)
private String mongoId;
@Field(type = Keyword)
private String authorName;
@Field(type = Keyword)
private String authorEmail;
private Map dataSet;
@Field(type = Keyword)
private Set taskIds;
@Field(type = Keyword)
private Set taskMongoIds;
@Field(type = Keyword)
private Set enabledRoles;
@Field(type = Keyword)
private Set viewRoles;
@Field(type = Keyword)
private Set viewUserRefs;
@Field(type = Keyword)
private Set negativeViewRoles;
private Set viewUsers;
@Field(type = Keyword)
private Set negativeViewUsers;
private Map tags;
/**
* Data that is stored in the elasticsearch database.
*
* Note that the dataSet attribute is NOT set when the object is created and must be set later.
*
* The {@link com.netgrif.application.engine.elastic.service.interfaces.IElasticCaseMappingService IElasticCaseMappingService} can be used to create
* instances of this class from Case objects, that have the dataset populated.
*
* @param useCase the data object that should be turned into elasticsearch data object
*/
public ElasticCase(Case useCase) {
stringId = useCase.getStringId();
uriNodeId = useCase.getUriNodeId();
mongoId = useCase.getStringId(); //TODO: Duplication
lastModified = Timestamp.valueOf(useCase.getLastModified()).getTime();
processIdentifier = useCase.getProcessIdentifier();
processId = useCase.getPetriNetId();
visualId = useCase.getVisualId();
title = useCase.getTitle();
creationDate = useCase.getCreationDate();
creationDateSortable = Timestamp.valueOf(useCase.getCreationDate()).getTime();
author = useCase.getAuthor().getId();
authorName = useCase.getAuthor().getFullName();
authorEmail = useCase.getAuthor().getEmail();
taskIds = useCase.getTasks().stream().map(TaskPair::getTransition).collect(Collectors.toSet());
taskMongoIds = useCase.getTasks().stream().map(TaskPair::getTask).collect(Collectors.toSet());
enabledRoles = new HashSet<>(useCase.getEnabledRoles());
viewRoles = new HashSet<>(useCase.getViewRoles());
viewUserRefs = new HashSet<>(useCase.getViewUserRefs());
negativeViewRoles = new HashSet<>(useCase.getNegativeViewRoles());
viewUsers = new HashSet<>(useCase.getViewUsers());
negativeViewUsers = new HashSet<>(useCase.getNegativeViewUsers());
tags = new HashMap<>(useCase.getTags());
dataSet = new HashMap<>();
}
public void update(ElasticCase useCase) {
version++;
lastModified = useCase.getLastModified();
if (useCase.getUriNodeId() != null) {
uriNodeId = useCase.getUriNodeId();
}
title = useCase.getTitle();
taskIds = useCase.getTaskIds();
taskMongoIds = useCase.getTaskMongoIds();
enabledRoles = useCase.getEnabledRoles();
viewRoles = useCase.getViewRoles();
viewUserRefs = useCase.getViewUserRefs();
negativeViewRoles = useCase.getNegativeViewRoles();
viewUsers = useCase.getViewUsers();
negativeViewUsers = useCase.getNegativeViewUsers();
tags = useCase.getTags();
dataSet = useCase.getDataSet();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy