blob: b77a9d3a7c895abef7e12f4b893202f1eaa70232 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with this
* work for additional information regarding copyright ownership. The ASF
* licenses this file to You under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*/
package org.apache.hugegraph.driver;
import org.apache.hugegraph.api.gremlin.GremlinAPI;
import org.apache.hugegraph.api.gremlin.GremlinRequest;
import org.apache.hugegraph.api.job.GremlinJobAPI;
import org.apache.hugegraph.client.RestClient;
import org.apache.hugegraph.structure.gremlin.Response;
import org.apache.hugegraph.structure.gremlin.ResultSet;
public class GremlinManager {
private final GraphManager graphManager;
private final GremlinAPI gremlinAPI;
private final GremlinJobAPI gremlinJobAPI;
private final String graphSpace;
private final String graph;
public GremlinManager(RestClient client, String graphSpace, String graph,
GraphManager graphManager) {
this.graphManager = graphManager;
this.gremlinAPI = new GremlinAPI(client);
this.gremlinJobAPI = new GremlinJobAPI(client, graphSpace, graph);
this.graphSpace = graphSpace;
this.graph = graph;
}
public ResultSet execute(GremlinRequest request) {
if (this.gremlinAPI.isSupportGs()) {
// Bind "graph" and graph space to all graphs
request.aliases.put("graph", this.graphSpace + "-" + this.graph);
// Bind "g" and graph space to all graphs by custom rule which define in gremlin server.
request.aliases.put("g", "__g_" + this.graphSpace + "-" + this.graph);
} else {
// Bind "graph" to all graphs
request.aliases.put("graph", this.graph);
// Bind "g" to all graphs by custom rule which define in gremlin server.
request.aliases.put("g", "__g_" + this.graph);
}
Response response = this.gremlinAPI.post(request);
response.graphManager(this.graphManager);
// TODO: Can add some checks later
return response.result();
}
public long executeAsTask(GremlinRequest request) {
return this.gremlinJobAPI.execute(request);
}
public GremlinRequest.Builder gremlin(String gremlin) {
return new GremlinRequest.Builder(gremlin, this);
}
}