Integrate loading openCypher module procedures
Summary:
All mgp_* symbols are exported from Memgraph executable, no other
symbols should be visible.
The primary C API header, mg_procedure.h, is now part of the
installation. Also, added a shippable query module example.
Directory `query_modules` is meant to contain sources of modules we
write and ship as part of the installation. Currently, there's only an
example module, but there may be potentially more. Some modules could
only be installed as part of the enterprise release.
For Memgraph to load custom procedures, it needs to be started with a
flag pointing to a directory with compiled shared libraries implementing
those procedures.
Reviewers: mferencevic, ipaljak, llugovic, dsantl, buda
Reviewed By: mferencevic
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D2538
2019-10-31 23:36:34 +08:00
|
|
|
// Compile with clang or gcc:
|
|
|
|
// clang -Wall -shared -fPIC -I <path-to-memgraph-include> example.c -o example.so
|
|
|
|
// <path-to-memgraph-include> for installed Memgraph will usually be something
|
|
|
|
// like `/usr/include/memgraph` or `/usr/local/include/memgraph`.
|
|
|
|
// To use the compiled module, you need to run Memgraph configured to load
|
|
|
|
// modules from the directory where the compiled module can be found.
|
|
|
|
#include "mg_procedure.h"
|
|
|
|
|
|
|
|
// This example procedure returns 2 fields: `args` and `result`.
|
|
|
|
// * `args` is a copy of arguments passed to the procedure.
|
|
|
|
// * `result` is the result of this procedure, a "Hello World!" string.
|
2019-11-14 22:54:10 +08:00
|
|
|
// In case of memory errors, this function will report them and finish
|
|
|
|
// executing.
|
Integrate loading openCypher module procedures
Summary:
All mgp_* symbols are exported from Memgraph executable, no other
symbols should be visible.
The primary C API header, mg_procedure.h, is now part of the
installation. Also, added a shippable query module example.
Directory `query_modules` is meant to contain sources of modules we
write and ship as part of the installation. Currently, there's only an
example module, but there may be potentially more. Some modules could
only be installed as part of the enterprise release.
For Memgraph to load custom procedures, it needs to be started with a
flag pointing to a directory with compiled shared libraries implementing
those procedures.
Reviewers: mferencevic, ipaljak, llugovic, dsantl, buda
Reviewed By: mferencevic
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D2538
2019-10-31 23:36:34 +08:00
|
|
|
//
|
|
|
|
// The procedure can be invoked in openCypher using the following call:
|
2019-11-14 22:54:10 +08:00
|
|
|
// CALL example.procedure(1, 2, 3) YIELD args, result;
|
Integrate loading openCypher module procedures
Summary:
All mgp_* symbols are exported from Memgraph executable, no other
symbols should be visible.
The primary C API header, mg_procedure.h, is now part of the
installation. Also, added a shippable query module example.
Directory `query_modules` is meant to contain sources of modules we
write and ship as part of the installation. Currently, there's only an
example module, but there may be potentially more. Some modules could
only be installed as part of the enterprise release.
For Memgraph to load custom procedures, it needs to be started with a
flag pointing to a directory with compiled shared libraries implementing
those procedures.
Reviewers: mferencevic, ipaljak, llugovic, dsantl, buda
Reviewed By: mferencevic
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D2538
2019-10-31 23:36:34 +08:00
|
|
|
// Naturally, you may pass in different arguments or yield less fields.
|
2019-11-14 22:54:10 +08:00
|
|
|
static void procedure(const struct mgp_list *args,
|
|
|
|
const struct mgp_graph *graph, struct mgp_result *result,
|
|
|
|
struct mgp_memory *memory) {
|
Integrate loading openCypher module procedures
Summary:
All mgp_* symbols are exported from Memgraph executable, no other
symbols should be visible.
The primary C API header, mg_procedure.h, is now part of the
installation. Also, added a shippable query module example.
Directory `query_modules` is meant to contain sources of modules we
write and ship as part of the installation. Currently, there's only an
example module, but there may be potentially more. Some modules could
only be installed as part of the enterprise release.
For Memgraph to load custom procedures, it needs to be started with a
flag pointing to a directory with compiled shared libraries implementing
those procedures.
Reviewers: mferencevic, ipaljak, llugovic, dsantl, buda
Reviewed By: mferencevic
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D2538
2019-10-31 23:36:34 +08:00
|
|
|
struct mgp_list *args_copy = mgp_list_make_empty(mgp_list_size(args), memory);
|
|
|
|
if (args_copy == NULL) goto error_memory;
|
|
|
|
for (size_t i = 0; i < mgp_list_size(args); ++i) {
|
|
|
|
int success = mgp_list_append(args_copy, mgp_list_at(args, i));
|
|
|
|
if (!success) goto error_free_list;
|
|
|
|
}
|
|
|
|
struct mgp_result_record *record = mgp_result_new_record(result);
|
|
|
|
if (record == NULL) goto error_free_list;
|
|
|
|
// Transfer ownership of args_copy to mgp_value.
|
|
|
|
struct mgp_value *args_value = mgp_value_make_list(args_copy);
|
|
|
|
if (args_value == NULL) goto error_free_list;
|
|
|
|
int args_inserted = mgp_result_record_insert(record, "args", args_value);
|
|
|
|
// Release `args_value` and contained `args_copy`.
|
|
|
|
mgp_value_destroy(args_value);
|
|
|
|
if (!args_inserted) goto error_memory;
|
|
|
|
struct mgp_value *hello_world_value =
|
|
|
|
mgp_value_make_string("Hello World!", memory);
|
|
|
|
if (hello_world_value == NULL) goto error_memory;
|
|
|
|
int result_inserted =
|
|
|
|
mgp_result_record_insert(record, "result", hello_world_value);
|
|
|
|
mgp_value_destroy(hello_world_value);
|
|
|
|
if (!result_inserted) goto error_memory;
|
|
|
|
// We have successfully finished, so return without error reporting.
|
|
|
|
return;
|
|
|
|
|
|
|
|
error_free_list:
|
|
|
|
mgp_list_destroy(args_copy);
|
|
|
|
error_memory:
|
|
|
|
mgp_result_set_error_msg(result, "Not enough memory!");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2019-11-14 22:54:10 +08:00
|
|
|
// Each module needs to define mgp_init_module function.
|
|
|
|
// Here you can register multiple procedures your module supports.
|
|
|
|
int mgp_init_module(struct mgp_module *module, struct mgp_memory *memory) {
|
|
|
|
struct mgp_proc *proc =
|
|
|
|
mgp_module_add_read_procedure(module, "procedure", procedure);
|
|
|
|
if (!proc) return 1;
|
|
|
|
if (!mgp_proc_add_arg(proc, "required_arg",
|
|
|
|
mgp_type_nullable(mgp_type_any())))
|
|
|
|
return 1;
|
|
|
|
struct mgp_value *null_value = mgp_value_make_null(memory);
|
|
|
|
if (!mgp_proc_add_opt_arg(proc, "optional_arg",
|
|
|
|
mgp_type_nullable(mgp_type_any()), null_value)) {
|
|
|
|
mgp_value_destroy(null_value);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
mgp_value_destroy(null_value);
|
|
|
|
if (!mgp_proc_add_result(proc, "result", mgp_type_string())) return 1;
|
|
|
|
if (!mgp_proc_add_result(proc, "args", mgp_type_list(mgp_type_any())))
|
|
|
|
return 1;
|
Integrate loading openCypher module procedures
Summary:
All mgp_* symbols are exported from Memgraph executable, no other
symbols should be visible.
The primary C API header, mg_procedure.h, is now part of the
installation. Also, added a shippable query module example.
Directory `query_modules` is meant to contain sources of modules we
write and ship as part of the installation. Currently, there's only an
example module, but there may be potentially more. Some modules could
only be installed as part of the enterprise release.
For Memgraph to load custom procedures, it needs to be started with a
flag pointing to a directory with compiled shared libraries implementing
those procedures.
Reviewers: mferencevic, ipaljak, llugovic, dsantl, buda
Reviewed By: mferencevic
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D2538
2019-10-31 23:36:34 +08:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
// This is an optional function if you need to release any resources before the
|
|
|
|
// module is unloaded. You will probably need this if you acquired some
|
|
|
|
// resources in mgp_init_module.
|
|
|
|
int mgp_shutdown_module() {
|
|
|
|
// Return 0 to indicate success.
|
|
|
|
return 0;
|
|
|
|
}
|