memgraph/tests/e2e/transaction_rollback/procedures/procedures.cpp
2023-10-24 17:12:09 +02:00

95 lines
3.3 KiB
C++

// Copyright 2023 Memgraph Ltd.
//
// Use of this software is governed by the Business Source License
// included in the file licenses/BSL.txt; by using this file, you agree to be bound by the terms of the Business Source
// License, and you may not use this file except in compliance with the Business Source License.
//
// As of the Change Date specified in that file, in accordance with
// the Business Source License, use of this software will be governed
// by the Apache License, Version 2.0, included in the file
// licenses/APL.txt.
#include "mg_procedure.h"
#include "mgp.hpp"
namespace {
constexpr std::string_view ProcedureFrom = "set_from";
constexpr std::string_view ProcedureTo = "set_to";
constexpr std::string_view ProcedureChangeType = "change_type";
void SetFrom(mgp_list *args, mgp_graph *memgraph_graph, mgp_result *result, mgp_memory *memory) {
mgp::MemoryDispatcherGuard guard(memory);
const auto arguments = mgp::List(args);
try {
auto rel{arguments[0].ValueRelationship()};
auto new_from{arguments[1].ValueNode()};
mgp::Graph graph{memgraph_graph};
graph.SetFrom(rel, new_from);
} catch (const std::exception &e) {
return;
}
}
void SetTo(mgp_list *args, mgp_graph *memgraph_graph, mgp_result *result, mgp_memory *memory) {
mgp::MemoryDispatcherGuard guard(memory);
const auto arguments = mgp::List(args);
try {
auto rel{arguments[0].ValueRelationship()};
auto new_to{arguments[1].ValueNode()};
mgp::Graph graph{memgraph_graph};
graph.SetTo(rel, new_to);
} catch (const std::exception &e) {
return;
}
}
void ChangeType(mgp_list *args, mgp_graph *memgraph_graph, mgp_result *result, mgp_memory *memory) {
mgp::MemoryDispatcherGuard guard(memory);
const auto arguments = mgp::List(args);
try {
auto rel{arguments[0].ValueRelationship()};
auto new_type{arguments[1].ValueString()};
mgp::Graph graph{memgraph_graph};
graph.ChangeType(rel, new_type);
} catch (const std::exception &e) {
return;
}
}
} // namespace
// Each module needs to define mgp_init_module function.
// Here you can register multiple functions/procedures your module supports.
extern "C" int mgp_init_module(struct mgp_module *module, struct mgp_memory *memory) {
{
try {
mgp::MemoryDispatcherGuard guard(memory);
mgp::AddProcedure(
SetFrom, ProcedureFrom, mgp::ProcedureType::Write,
{mgp::Parameter("relationship", mgp::Type::Relationship), mgp::Parameter("node_from", mgp::Type::Node)}, {},
module, memory);
mgp::AddProcedure(
SetTo, ProcedureTo, mgp::ProcedureType::Write,
{mgp::Parameter("relationship", mgp::Type::Relationship), mgp::Parameter("node_to", mgp::Type::Node)}, {},
module, memory);
mgp::AddProcedure(
ChangeType, ProcedureChangeType, mgp::ProcedureType::Write,
{mgp::Parameter("relationship", mgp::Type::Relationship), mgp::Parameter("new_type", mgp::Type::String)}, {},
module, memory);
} catch (const std::exception &e) {
return 1;
}
}
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.
extern "C" int mgp_shutdown_module() { return 0; }