Skip to content

Commit

Permalink
Merge branch 'main' into refine-ci
Browse files Browse the repository at this point in the history
  • Loading branch information
Thespica authored Aug 22, 2024
2 parents 34efa04 + 0de3c02 commit c3abcc1
Show file tree
Hide file tree
Showing 33 changed files with 739 additions and 519 deletions.
34 changes: 16 additions & 18 deletions docs/flex/interactive/development/dev_and_test.md
Original file line number Diff line number Diff line change
Expand Up @@ -214,27 +214,25 @@ The Compiler service could be started as a subprocess of the AdminService. This
```


### Mapping of Internal Code to Http Error Code
### Error Code

Runtime errors are categorized, assigned an error code, and included in the HTTP response body (only for non-200 HTTP responses).
The mapping between status codes and HTTP codes is shown in the table below.

Internally we use [`StatusCode`](https://github.com/alibaba/GraphScope/blob/main/flex/utils/result.h) to record the runtime errors.
The mapping between statusCode and http code is shown in the following table.

| Code | HTTP Code |
| ----------------------------------- | ----------- |
| gs::StatusCode::OK | 200 |
| gs::StatusCode::InValidArgument | 400 |
| gs::StatusCode::UnsupportedOperator | 400 |
| gs::StatusCode::AlreadyExists | 409 |
| gs::StatusCode::NotExists | 404 |
| gs::StatusCode::CodegenError | 500 |
| gs::StatusCode::UninitializedStatus | 500 |
| gs::StatusCode::InvalidSchema | 400 |
| gs::StatusCode::PermissionError | 403 |
| gs::StatusCode::IllegalOperation | 400 |
| gs::StatusCode::InternalError | 500 |
| gs::StatusCode::InvalidImportFile | 400 |
| gs::StatusCode::IOError | 500 |
| gs::StatusCode::NotFound | 404 |
| gs::StatusCode::QueryFailed | 500 |
| OK(0) | 200 |
| INVALID_ARGUMENT(2) | 400 |
| UNSUPPORTED_OPERATION(11) | 400 |
| NOT_FOUND(4) | 404 |
| ALREADY_EXISTS(5) | 409 |
| PERMISSION_DENIED(8) | 403 |
| CODEGEN_ERROR(100) | 500 |
| INVALID_SCHEMA(101) | 400 |
| ILLEGAL_OPERATION(102) | 400 |
| INTERNAL_ERROR(103) | 500 |
| INVALID_IMPORT_FILE(104) | 400 |
| IO_ERROR(105) | 500 |
| QUERY_FAILED(106) | 500 |
| default | 500 |
4 changes: 2 additions & 2 deletions flex/engines/graph_db/database/graph_db.cc
Original file line number Diff line number Diff line change
Expand Up @@ -97,13 +97,13 @@ Result<bool> GraphDB::Open(const GraphDBConfig& config) {
graph_.Open(data_dir, config.memory_level);
} catch (std::exception& e) {
LOG(ERROR) << "Exception: " << e.what();
return Result<bool>(StatusCode::InternalError,
return Result<bool>(StatusCode::INTERNAL_ERROR,
"Exception: " + std::string(e.what()), false);
}

if ((!create_empty_graph) && (!graph_.schema().Equals(schema))) {
LOG(ERROR) << "Schema inconsistent..\n";
return Result<bool>(StatusCode::InternalError,
return Result<bool>(StatusCode::INTERNAL_ERROR,
"Schema of work directory is not compatible with the "
"graph schema",
false);
Expand Down
40 changes: 20 additions & 20 deletions flex/engines/graph_db/database/graph_db_operations.cc
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ Result<std::string> GraphDBOperations::CreateVertex(
(input_json.contains("edge_request") == true &&
input_json["edge_request"].is_array() == false)) {
return Result<std::string>(
StatusCode::InvalidSchema,
StatusCode::INVALID_SCHEMA,
"Invalid input json, vertex_request and edge_request should be array "
"and not empty");
}
Expand All @@ -55,7 +55,7 @@ Result<std::string> GraphDBOperations::CreateVertex(
}
} catch (std::exception& e) {
return Result<std::string>(
StatusCode::InvalidSchema,
StatusCode::INVALID_SCHEMA,
" Bad input parameter : " + std::string(e.what()));
}
auto insert_result =
Expand All @@ -74,7 +74,7 @@ Result<std::string> GraphDBOperations::CreateEdge(GraphDBSession& session,
// Check if the input json contains edge_request
if (input_json.is_array() == false || input_json.size() == 0) {
return Result<std::string>(
StatusCode::InvalidSchema,
StatusCode::INVALID_SCHEMA,
"Invalid input json, edge_request should be array and not empty");
}
const Schema& schema = session.schema();
Expand All @@ -85,7 +85,7 @@ Result<std::string> GraphDBOperations::CreateEdge(GraphDBSession& session,
}
} catch (std::exception& e) {
return Result<std::string>(
StatusCode::InvalidSchema,
StatusCode::INVALID_SCHEMA,
" Bad input parameter : " + std::string(e.what()));
}
auto insert_result = insertEdge(std::move(edge_data), session);
Expand All @@ -106,7 +106,7 @@ Result<std::string> GraphDBOperations::UpdateVertex(
vertex_data.push_back(inputVertex(input_json, schema, session));
} catch (std::exception& e) {
return Result<std::string>(
StatusCode::InvalidSchema,
StatusCode::INVALID_SCHEMA,
" Bad input parameter : " + std::string(e.what()));
}
auto update_result = updateVertex(std::move(vertex_data), session);
Expand All @@ -127,7 +127,7 @@ Result<std::string> GraphDBOperations::UpdateEdge(GraphDBSession& session,
edge_data.push_back(inputEdge(input_json, schema, session));
} catch (std::exception& e) {
return Result<std::string>(
StatusCode::InvalidSchema,
StatusCode::INVALID_SCHEMA,
" Bad input parameter : " + std::string(e.what()));
}
auto update_result = updateEdge(std::move(edge_data), session);
Expand Down Expand Up @@ -206,13 +206,13 @@ Result<std::string> GraphDBOperations::GetEdge(
Result<std::string> GraphDBOperations::DeleteVertex(
GraphDBSession& session, nlohmann::json&& input_json) {
// not implemented
return Result<std::string>(StatusCode::Unimplemented,
return Result<std::string>(StatusCode::UNIMPLEMENTED,
"delete_vertex is not implemented");
}
Result<std::string> GraphDBOperations::DeleteEdge(GraphDBSession& session,
nlohmann::json&& input_json) {
// not implemented
return Result<std::string>(StatusCode::Unimplemented,
return Result<std::string>(StatusCode::UNIMPLEMENTED,
"delete_edge is not implemented");
}

Expand Down Expand Up @@ -298,7 +298,7 @@ Status GraphDBOperations::checkVertexSchema(
}
return Status::OK();
} catch (std::exception& e) {
return Status(StatusCode::InvalidSchema,
return Status(StatusCode::INVALID_SCHEMA,
" Bad input parameter : " + std::string(e.what()));
}
}
Expand Down Expand Up @@ -338,7 +338,7 @@ Status GraphDBOperations::checkEdgeSchema(const Schema& schema, EdgeData& edge,
std::get<0>(schema.get_vertex_primary_key(edge.dst_label_id)[0]));
return Status::OK();
} catch (std::exception& e) {
return Status(StatusCode::InvalidSchema,
return Status(StatusCode::INVALID_SCHEMA,
" Bad input parameter : " + std::string(e.what()));
}
}
Expand Down Expand Up @@ -368,7 +368,7 @@ Status GraphDBOperations::checkEdgeExistsWithInsert(
}
}
} catch (std::exception& e) {
return Status(StatusCode::InvalidSchema, e.what());
return Status(StatusCode::INVALID_SCHEMA, e.what());
}
return Status::OK();
}
Expand Down Expand Up @@ -398,7 +398,7 @@ Status GraphDBOperations::checkEdgeExists(
}
}
} catch (std::exception& e) {
return Status(StatusCode::InvalidSchema, e.what());
return Status(StatusCode::INVALID_SCHEMA, e.what());
}
return Status::OK();
}
Expand All @@ -417,7 +417,7 @@ Status GraphDBOperations::checkVertexExists(
}
txn.Commit();
} catch (std::exception& e) {
return Status(StatusCode::InvalidSchema, e.what());
return Status(StatusCode::INVALID_SCHEMA, e.what());
}
return Status::OK();
}
Expand Down Expand Up @@ -445,7 +445,7 @@ Status GraphDBOperations::singleInsertVertex(
}
txnWrite.Commit();
} catch (std::exception& e) {
return Status(StatusCode::InvalidSchema, e.what());
return Status(StatusCode::INVALID_SCHEMA, e.what());
}
return Status::OK();
}
Expand Down Expand Up @@ -474,7 +474,7 @@ Status GraphDBOperations::multiInsert(std::vector<VertexData>&& vertex_data,
}
txnWrite.Commit();
} catch (std::exception& e) {
return Status(StatusCode::InvalidSchema, e.what());
return Status(StatusCode::INVALID_SCHEMA, e.what());
}
return Status::OK();
}
Expand Down Expand Up @@ -512,7 +512,7 @@ Status GraphDBOperations::singleInsertEdge(std::vector<EdgeData>&& edge_data,
}
txnWrite.Commit();
} catch (std::exception& e) {
return Status(StatusCode::InvalidSchema, e.what());
return Status(StatusCode::INVALID_SCHEMA, e.what());
}
return Status::OK();
}
Expand Down Expand Up @@ -553,7 +553,7 @@ Status GraphDBOperations::updateVertex(std::vector<VertexData>&& vertex_data,
}
txnWrite.Commit();
} catch (std::exception& e) {
return Status(StatusCode::InvalidSchema, e.what());
return Status(StatusCode::INVALID_SCHEMA, e.what());
}
return Status::OK();
}
Expand Down Expand Up @@ -590,7 +590,7 @@ Status GraphDBOperations::updateEdge(std::vector<EdgeData>&& edge_data,
dst_vid, edge.edge_label_id, edge.property_value);
txn2.Commit();
} catch (std::exception& e) {
return Status(StatusCode::InvalidSchema, e.what());
return Status(StatusCode::INVALID_SCHEMA, e.what());
}
return Status::OK();
}
Expand All @@ -616,7 +616,7 @@ Result<nlohmann::json> GraphDBOperations::getVertex(
txn.Commit();
return Result<nlohmann::json>(result);
} catch (std::exception& e) {
return Result<nlohmann::json>(Status(StatusCode::InvalidSchema, e.what()));
return Result<nlohmann::json>(Status(StatusCode::INVALID_SCHEMA, e.what()));
}
}

Expand Down Expand Up @@ -653,7 +653,7 @@ Result<nlohmann::json> GraphDBOperations::getEdge(
txn.Commit();
return Result<nlohmann::json>(result);
} catch (std::exception& e) {
return Result<nlohmann::json>(Status(StatusCode::InvalidSchema, e.what()));
return Result<nlohmann::json>(Status(StatusCode::INVALID_SCHEMA, e.what()));
}
}

Expand Down
16 changes: 8 additions & 8 deletions flex/engines/graph_db/database/graph_db_session.cc
Original file line number Diff line number Diff line change
Expand Up @@ -111,7 +111,7 @@ Result<std::vector<char>> GraphDBSession::Eval(const std::string& input) {

if (input.size() < 2) {
return Result<std::vector<char>>(
StatusCode::InValidArgument,
StatusCode::INVALID_ARGUMENT,
"Invalid input, input size: " + std::to_string(input.size()),
std::vector<char>());
}
Expand All @@ -134,7 +134,7 @@ Result<std::vector<char>> GraphDBSession::Eval(const std::string& input) {
AppBase* app = GetApp(type);
if (!app) {
return Result<std::vector<char>>(
StatusCode::NotFound,
StatusCode::NOT_FOUND,
"Procedure not found, id:" + std::to_string((int) type), result_buffer);
}

Expand Down Expand Up @@ -167,7 +167,7 @@ Result<std::vector<char>> GraphDBSession::Eval(const std::string& input) {
.count());
++query_num_;
return Result<std::vector<char>>(
StatusCode::QueryFailed,
StatusCode::QUERY_FAILED,
"Query failed for procedure id:" + std::to_string((int) type),
result_buffer);
}
Expand Down Expand Up @@ -237,15 +237,15 @@ GraphDBSession::parse_query_type_from_cypher_json(
} catch (const nlohmann::json::parse_error& e) {
LOG(ERROR) << "Fail to parse json from input content: " << e.what();
return Result<std::pair<uint8_t, std::string_view>>(gs::Status(
StatusCode::InternalError,
StatusCode::INTERNAL_ERROR,
"Fail to parse json from input content:" + std::string(e.what())));
}
auto query_name = j["query_name"].get<std::string>();
const auto& app_name_to_path_index = schema().GetPlugins();
if (app_name_to_path_index.count(query_name) <= 0) {
LOG(ERROR) << "Query name is not registered: " << query_name;
return Result<std::pair<uint8_t, std::string_view>>(gs::Status(
StatusCode::NotFound, "Query name is not registered: " + query_name));
StatusCode::NOT_FOUND, "Query name is not registered: " + query_name));
}
if (j.contains("arguments")) {
for (auto& arg : j["arguments"]) {
Expand All @@ -263,19 +263,19 @@ GraphDBSession::parse_query_type_from_cypher_internal(
if (!cur_query.ParseFromArray(str_view.data(), str_view.size())) {
LOG(ERROR) << "Fail to parse query from input content";
return Result<std::pair<uint8_t, std::string_view>>(gs::Status(
StatusCode::InternalError, "Fail to parse query from input content"));
StatusCode::INTERNAL_ERROR, "Fail to parse query from input content"));
}
auto query_name = cur_query.query_name().name();
if (query_name.empty()) {
LOG(ERROR) << "Query name is empty";
return Result<std::pair<uint8_t, std::string_view>>(
gs::Status(StatusCode::NotFound, "Query name is empty"));
gs::Status(StatusCode::NOT_FOUND, "Query name is empty"));
}
const auto& app_name_to_path_index = schema().GetPlugins();
if (app_name_to_path_index.count(query_name) <= 0) {
LOG(ERROR) << "Query name is not registered: " << query_name;
return Result<std::pair<uint8_t, std::string_view>>(gs::Status(
StatusCode::NotFound, "Query name is not registered: " + query_name));
StatusCode::NOT_FOUND, "Query name is not registered: " + query_name));
}
return std::make_pair(app_name_to_path_index.at(query_name).second, str_view);
}
Expand Down
2 changes: 1 addition & 1 deletion flex/engines/graph_db/database/graph_db_session.h
Original file line number Diff line number Diff line change
Expand Up @@ -169,7 +169,7 @@ class GraphDBSession {

} else {
return Result<std::pair<uint8_t, std::string_view>>(
gs::Status(StatusCode::InValidArgument,
gs::Status(StatusCode::INVALID_ARGUMENT,
"Invalid input tag: " + std::to_string(input_tag)));
}
}
Expand Down
1 change: 1 addition & 0 deletions flex/engines/http_server/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ if (Hiactor_FOUND)
list(FILTER SERVER_FILES EXCLUDE REGEX ".*generated.*")

add_library(flex_server STATIC ${SERVER_FILES} ${server_actor_autogen_files})
add_dependencies(flex_server flex_utils) # Make sure flex_utils is built before flex_server
add_dependencies(flex_server server_actor_autogen)
target_compile_options (flex_server
PUBLIC
Expand Down
Loading

0 comments on commit c3abcc1

Please sign in to comment.