
com.eventsourcing.cep.protocols.DeletedProtocol Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of eventsourcing-cep Show documentation
Show all versions of eventsourcing-cep Show documentation
Event capture and querying framework for Java
The newest version!
/**
* Copyright (c) 2016, All Contributors (see CONTRIBUTORS file)
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*/
package com.eventsourcing.cep.protocols;
import com.eventsourcing.Entity;
import com.eventsourcing.EntityHandle;
import com.eventsourcing.Protocol;
import com.eventsourcing.Repository;
import com.eventsourcing.cep.events.Deleted;
import com.eventsourcing.cep.events.Undeleted;
import com.eventsourcing.index.EntityIndex;
import com.eventsourcing.queries.ModelCollectionQuery;
import com.eventsourcing.queries.ModelLoader;
import com.eventsourcing.queries.ModelQueries;
import com.googlecode.cqengine.IndexedCollection;
import com.googlecode.cqengine.query.Query;
import com.googlecode.cqengine.query.logical.Not;
import com.googlecode.cqengine.resultset.ResultSet;
import org.unprotocols.coss.Draft;
import org.unprotocols.coss.RFC;
import java.util.Optional;
import java.util.UUID;
import java.util.function.Function;
import java.util.stream.Stream;
import static com.eventsourcing.index.EntityQueryFactory.*;
import static com.eventsourcing.queries.QueryFactory.isLatestEntity;
import static com.googlecode.cqengine.stream.StreamFactory.streamOf;
@Draft @RFC(url = "http://rfc.eventsourcing.com/spec:3/CEP")
public interface DeletedProtocol extends Protocol, ModelQueries {
default Optional deleted() {
Not> additionalQuery = not(existsIn(getRepository().getIndexEngine()
.getIndexedCollection(Undeleted.class),
Deleted.ID, Undeleted.DELETED_ID));
return latestAssociatedEntity(Deleted.class, Deleted.REFERENCE_ID, Deleted.TIMESTAMP, additionalQuery);
}
class DeletedModelCollectionQuery implements ModelCollectionQuery {
private final ModelLoader loader;
public DeletedModelCollectionQuery(ModelLoader loader) {
this.loader = loader;
}
@Override public Stream getCollectionStream(Repository repository) {
IndexedCollection> deletedCollection = repository.getIndexEngine()
.getIndexedCollection(Deleted.class);
IndexedCollection> undeletedCollection = repository.getIndexEngine()
.getIndexedCollection(
Undeleted.class);
Query> query = and(not(existsIn(undeletedCollection, Deleted.ID, Undeleted.DELETED_ID)),
isLatestEntity(deletedCollection,
new DeletedQueryFunction(), Deleted.TIMESTAMP));
ResultSet> resultSet = repository.query(Deleted.class, query);
return streamOf(resultSet)
.map(h -> loader.load(repository, h.get().reference()).get())
.onClose(resultSet::close);
}
private static class DeletedQueryFunction implements Function, Query>> {
@Override public Query> apply(EntityHandle v) {
return equal(Deleted.REFERENCE_ID, v.uuid());
}
}
}
class NotDeletedModelCollectionQuery implements
ModelCollectionQuery {
private final Class klass;
private final EntityIndex idAttribute;
private final ModelLoader loader;
public NotDeletedModelCollectionQuery(Class klass,
EntityIndex idAttribute,
ModelLoader loader) {
this.klass = klass;
this.idAttribute = idAttribute;
this.loader = loader;
}
@Override public Stream getCollectionStream(Repository repository) {
IndexedCollection> deletedCollection =
repository.getIndexEngine().getIndexedCollection(Deleted.class);
IndexedCollection> undeletedCollection =
repository.getIndexEngine().getIndexedCollection(Undeleted.class);
ResultSet> resultSet = repository
.query(klass, not(existsIn(deletedCollection, idAttribute, Deleted.REFERENCE_ID,
not(existsIn(undeletedCollection, Deleted.ID, Undeleted.DELETED_ID)))));
return streamOf(resultSet)
.map(h -> loader.load(repository, h.get().uuid()).get())
.onClose(resultSet::close);
}
}
static ModelCollectionQuery deleted(ModelLoader loader) {
return new DeletedModelCollectionQuery<>(loader);
}
static ModelCollectionQuery
notDeleted(Class klass, EntityIndex idAttribute, ModelLoader loader) {
return new NotDeletedModelCollectionQuery<>(klass, idAttribute, loader);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy