108 lines
3.4 KiB
C++
108 lines
3.4 KiB
C++
/*
|
|
* Copyright (c) 2018 MariaDB Corporation Ab
|
|
*
|
|
* Use of this software is governed by the Business Source License included
|
|
* in the LICENSE.TXT file and at www.mariadb.com/bsl11.
|
|
*
|
|
* Change Date: 2023-11-12
|
|
*
|
|
* On the date above, in accordance with the Business Source License, use
|
|
* of this software will be governed by version 2 or later of the General
|
|
* Public License.
|
|
*/
|
|
|
|
#include "clustrixmon.hh"
|
|
#include <maxscale/modinfo.h>
|
|
#include <maxscale/modulecmd.hh>
|
|
#include "clustrixmonitor.hh"
|
|
|
|
namespace
|
|
{
|
|
|
|
bool handle_softfail(const MODULECMD_ARG* args, json_t** error_out)
|
|
{
|
|
mxb_assert(args->argc == 2);
|
|
mxb_assert(MODULECMD_GET_TYPE(&args->argv[0].type) == MODULECMD_ARG_MONITOR);
|
|
mxb_assert(MODULECMD_GET_TYPE(&args->argv[1].type) == MODULECMD_ARG_SERVER);
|
|
|
|
ClustrixMonitor* pMon = static_cast<ClustrixMonitor*>(args->argv[0].value.monitor);
|
|
SERVER* pServer = args->argv[1].value.server;
|
|
|
|
return pMon->softfail(pServer, error_out);
|
|
}
|
|
|
|
bool handle_unsoftfail(const MODULECMD_ARG* args, json_t** error_out)
|
|
{
|
|
mxb_assert(args->argc == 2);
|
|
mxb_assert(MODULECMD_GET_TYPE(&args->argv[0].type) == MODULECMD_ARG_MONITOR);
|
|
mxb_assert(MODULECMD_GET_TYPE(&args->argv[1].type) == MODULECMD_ARG_SERVER);
|
|
|
|
ClustrixMonitor* pMon = static_cast<ClustrixMonitor*>(args->argv[0].value.monitor);
|
|
SERVER* pServer = args->argv[1].value.server;
|
|
|
|
return pMon->unsoftfail(pServer, error_out);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* The module entry point routine. It is this routine that
|
|
* must populate the structure that is referred to as the
|
|
* "module object", this is a structure with the set of
|
|
* external entry points for this module.
|
|
*
|
|
* @return The module object
|
|
*/
|
|
extern "C" MXS_MODULE* MXS_CREATE_MODULE()
|
|
{
|
|
MXS_NOTICE("Initialise the MariaDB Clustrix Monitor module.");
|
|
|
|
static modulecmd_arg_type_t softfail_argv[] =
|
|
{
|
|
{
|
|
MODULECMD_ARG_MONITOR | MODULECMD_ARG_NAME_MATCHES_DOMAIN,
|
|
"Monitor name (from configuration file)"
|
|
},
|
|
{
|
|
MODULECMD_ARG_SERVER, "Node to be softfailed."
|
|
}
|
|
};
|
|
|
|
modulecmd_register_command(MXS_MODULE_NAME, "softfail", MODULECMD_TYPE_ACTIVE,
|
|
handle_softfail, MXS_ARRAY_NELEMS(softfail_argv), softfail_argv,
|
|
"Perform softfail of node");
|
|
|
|
static modulecmd_arg_type_t unsoftfail_argv[] =
|
|
{
|
|
{
|
|
MODULECMD_ARG_MONITOR | MODULECMD_ARG_NAME_MATCHES_DOMAIN,
|
|
"Monitor name (from configuration file)"
|
|
},
|
|
{
|
|
MODULECMD_ARG_SERVER, "Node to be unsoftfailed."
|
|
}
|
|
};
|
|
|
|
modulecmd_register_command(MXS_MODULE_NAME, "unsoftfail", MODULECMD_TYPE_ACTIVE,
|
|
handle_unsoftfail, MXS_ARRAY_NELEMS(unsoftfail_argv), unsoftfail_argv,
|
|
"Perform unsoftfail of node");
|
|
|
|
static MXS_MODULE info =
|
|
{
|
|
MXS_MODULE_API_MONITOR,
|
|
MXS_MODULE_GA,
|
|
MXS_MONITOR_VERSION,
|
|
"A Clustrix cluster monitor",
|
|
"V1.0.0",
|
|
MXS_NO_MODULE_CAPABILITIES,
|
|
&maxscale::MonitorApi<ClustrixMonitor>::s_api,
|
|
NULL, /* Process init. */
|
|
NULL, /* Process finish. */
|
|
NULL, /* Thread init. */
|
|
NULL, /* Thread finish. */
|
|
};
|
|
|
|
ClustrixMonitor::Config::populate(info);
|
|
|
|
return &info;
|
|
}
|