use of uk.gov.gchq.gaffer.data.element.id.EntityId in project Gaffer by gchq.
the class VisibilityTest method sourceAndDestinationFrom.
private static Set<EntityId> sourceAndDestinationFrom(final Edge edge) {
final Set<EntityId> nodes = new HashSet<>();
nodes.add(new EntitySeed(edge.getSource()));
nodes.add(new EntitySeed(edge.getDestination()));
return nodes;
}
use of uk.gov.gchq.gaffer.data.element.id.EntityId in project gaffer-doc by gchq.
the class NamedOperations method run.
public CloseableIterable<? extends Element> run() throws OperationException, IOException {
// / [graph] create a graph using our schema and store properties
// ---------------------------------------------------------
final Graph graph = new Graph.Builder().config(getDefaultGraphConfig()).addSchemas(StreamUtil.openStreams(getClass(), schemaPath)).storeProperties(getDefaultStoreProperties()).build();
// ---------------------------------------------------------
// [user] Create a user
// ---------------------------------------------------------
final User user = new User("user01");
// ---------------------------------------------------------
// [add] Create a data generator and add the edges to the graph using an operation chain consisting of:
// generateElements - generating edges from the data (note these are directed edges)
// addElements - add the edges to the graph
// ---------------------------------------------------------
final OperationChain<Void> addOpChain = new OperationChain.Builder().first(new GenerateElements.Builder<String>().generator(new RoadAndRoadUseWithTimesAndCardinalitiesElementGenerator()).input(IOUtils.readLines(StreamUtil.openStream(getClass(), "RoadAndRoadUseWithTimesAndCardinalities/data.txt"))).build()).then(new AddElements()).build();
graph.execute(addOpChain, user);
// ---------------------------------------------------------
// [add named operation] create an operation chain to be executed as a named operation
// ---------------------------------------------------------
final AddNamedOperation addOperation = new AddNamedOperation.Builder().operationChain(new OperationChain.Builder().first(new GetElements.Builder().view(new View.Builder().edge("RoadUse").build()).build()).then(new Limit.Builder<>().resultLimit(10).build()).build()).description("named operation limit query").name("2-limit").readAccessRoles("read-user").writeAccessRoles("write-user").score(2).overwrite().build();
graph.execute(addOperation, user);
// ---------------------------------------------------------
// [get all named operations] Get all named operations
// ---------------------------------------------------------
final CloseableIterable<NamedOperationDetail> details = graph.execute(new GetAllNamedOperations(), user);
// ---------------------------------------------------------
for (final NamedOperationDetail detail : details) {
print("ALL_NAMED_OPERATIONS", detail.toString());
}
// [create named operation] create the named operation
// ---------------------------------------------------------
final NamedOperation<EntityId, CloseableIterable<? extends Element>> operation = new NamedOperation.Builder<EntityId, CloseableIterable<? extends Element>>().name("2-limit").input(new EntitySeed("10")).build();
// ---------------------------------------------------------
// [execute named operation] Get the results
// ---------------------------------------------------------
final CloseableIterable<? extends Element> results = graph.execute(operation, user);
// ---------------------------------------------------------
for (final Object result : results) {
print("NAMED_OPERATION_RESULTS", result.toString());
}
// [add named operation with parameters] create an operation chain to be executed as a named operation
// with parameters
// ---------------------------------------------------------
String opChainString = "{" + " \"operations\" : [ {" + " \"class\" : \"uk.gov.gchq.gaffer.operation.impl.get.GetElements\"," + " \"view\" : {" + " \"edges\" : {" + " \"RoadUse\" : { }" + " }," + " \"entities\" : { }" + " }" + " }, {" + " \"class\" : \"uk.gov.gchq.gaffer.operation.impl.Limit\"," + " \"resultLimit\" : \"${limitParam}\"" + " } ]" + "}";
ParameterDetail param = new ParameterDetail.Builder().defaultValue(1L).description("Limit param").valueClass(Long.class).build();
Map<String, ParameterDetail> paramDetailMap = Maps.newHashMap();
paramDetailMap.put("limitParam", param);
final AddNamedOperation addOperationWithParams = new AddNamedOperation.Builder().operationChain(opChainString).description("named operation limit query").name("custom-limit").readAccessRoles("read-user").writeAccessRoles("write-user").parameters(paramDetailMap).overwrite().build();
graph.execute(addOperationWithParams, user);
// ---------------------------------------------------------
// [create named operation with parameters] create the named operation with a parameter
// ---------------------------------------------------------
Map<String, Object> paramMap = Maps.newHashMap();
paramMap.put("limitParam", 3L);
final NamedOperation<EntityId, CloseableIterable<? extends Element>> operationWithParams = new NamedOperation.Builder<EntityId, CloseableIterable<? extends Element>>().name("custom-limit").input(new EntitySeed("10")).parameters(paramMap).build();
// ---------------------------------------------------------
// [execute named operation with parameters] Get the results
// ---------------------------------------------------------
final CloseableIterable<? extends Element> namedOperationResults = graph.execute(operationWithParams, user);
for (final Object result : namedOperationResults) {
print("NAMED_OPERATION_WITH_PARAMETER_RESULTS", result.toString());
}
return namedOperationResults;
}
use of uk.gov.gchq.gaffer.data.element.id.EntityId in project gaffer-doc by gchq.
the class NamedOperationExample method runNamedOperationWithParameter.
public CloseableIterable<EntityId> runNamedOperationWithParameter() {
// ---------------------------------------------------------
Map<String, Object> paramMap = Maps.newHashMap();
paramMap.put("param1", 2L);
final NamedOperation<EntityId, CloseableIterable<EntityId>> operation = new NamedOperation.Builder<EntityId, CloseableIterable<EntityId>>().name("2-hop-with-limit").input(new EntitySeed(1)).parameters(paramMap).build();
return runExample(operation, null);
}
use of uk.gov.gchq.gaffer.data.element.id.EntityId in project gaffer-doc by gchq.
the class IfExample method runParameterisedNamedOperationContainingIfOperation.
public CloseableIterable<? extends Element> runParameterisedNamedOperationContainingIfOperation() {
// ---------------------------------------------------------
final java.util.Map<String, Object> parameterValues = Maps.newHashMap();
parameterValues.put("enableFiltering", true);
final NamedOperation<EntityId, CloseableIterable<? extends Element>> namedOp = new NamedOperation.Builder<EntityId, CloseableIterable<? extends Element>>().name("2-hop-with-optional-filtering").input(new EntitySeed(6)).parameters(parameterValues).build();
// ---------------------------------------------------------
return runExample(namedOp, "This example then runs the NamedOperation, " + "providing both the input, and the value of the parameter via a Map.");
}
use of uk.gov.gchq.gaffer.data.element.id.EntityId in project Gaffer by gchq.
the class OperationUtilTest method shouldConvertObjectArrayToEntityIds.
@Test
public void shouldConvertObjectArrayToEntityIds() {
// Given
final Object[] input = { 1, "2", new EntitySeed("3"), new Entity("group", "4"), null };
// When
final Iterable<? extends EntityId> output = OperationUtil.toEntityIds(input);
// Then
final ArrayList<EntityId> expected = Lists.newArrayList(new EntitySeed(1), new EntitySeed("2"), new EntitySeed("3"), new Entity("group", "4"), null);
assertEquals(expected, Lists.newArrayList(output));
}
Aggregations