mirror of https://github.com/sysown/proxysql
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
156 lines
5.0 KiB
156 lines
5.0 KiB
#ifndef PROXYSQL_PLUGIN_H
|
|
#define PROXYSQL_PLUGIN_H
|
|
|
|
#include <cstdint>
|
|
#include <string>
|
|
|
|
class SQLite3DB;
|
|
class SQLite3_result;
|
|
|
|
enum class ProxySQL_PluginDBKind : uint8_t {
|
|
admin_db = 0,
|
|
config_db = 1,
|
|
stats_db = 2
|
|
};
|
|
|
|
// The manager deep-copies table_name and table_def; the plugin need not keep
|
|
// the pointed-to strings alive after register_table returns.
|
|
struct ProxySQL_PluginTableDef {
|
|
ProxySQL_PluginDBKind db_kind;
|
|
const char *table_name;
|
|
const char *table_def;
|
|
};
|
|
|
|
// Borrowed DB handles valid for the duration of the admin command callback.
|
|
// Must not be stored beyond the callback invocation.
|
|
struct ProxySQL_PluginCommandContext {
|
|
SQLite3DB *admindb;
|
|
SQLite3DB *configdb;
|
|
SQLite3DB *statsdb;
|
|
};
|
|
|
|
// NOTE: ProxySQL_PluginCommandResult contains std::string. Plugins MUST
|
|
// be compiled with the same C++ standard library (same compiler, same
|
|
// -std= flag, same libstdc++/libc++ version) as the ProxySQL core.
|
|
// This is guaranteed when plugins are built within the ProxySQL build
|
|
// tree. Third-party plugins must match the core's build environment.
|
|
struct ProxySQL_PluginCommandResult {
|
|
int error_code;
|
|
uint64_t rows_affected;
|
|
std::string message;
|
|
};
|
|
|
|
using proxysql_plugin_admin_command_cb =
|
|
ProxySQL_PluginCommandResult (*)(const ProxySQL_PluginCommandContext &, const char *);
|
|
|
|
using proxysql_plugin_register_table_cb =
|
|
void (*)(const ProxySQL_PluginTableDef &);
|
|
|
|
using proxysql_plugin_register_command_cb =
|
|
void (*)(const char *, proxysql_plugin_admin_command_cb);
|
|
|
|
using proxysql_plugin_snapshot_cb =
|
|
SQLite3_result *(*)();
|
|
|
|
using proxysql_plugin_db_handle_cb =
|
|
SQLite3DB *(*)();
|
|
|
|
using proxysql_plugin_log_message_cb =
|
|
void (*)(int, const char *);
|
|
|
|
// Pre-execution query hook (Step 2 ABI extension).
|
|
//
|
|
// Wire protocol the hook is being invoked for. A plugin can register
|
|
// independently for each protocol; one hook per protocol per plugin.
|
|
enum class ProxySQL_PluginProtocol : uint8_t {
|
|
mysql = 0,
|
|
pgsql = 1
|
|
};
|
|
|
|
// Payload handed to a query-hook callback. All pointers are owned by
|
|
// core and remain valid only for the duration of the callback. The
|
|
// callback must not retain them or mutate the underlying buffers.
|
|
//
|
|
// query_text is the SQL the client sent, NOT NUL-terminated; query_len
|
|
// is its length in bytes. user / client_ip / schema are NUL-terminated
|
|
// C strings and may be empty (never NULL).
|
|
struct ProxySQL_PluginQueryHookPayload {
|
|
const char *user;
|
|
const char *client_ip;
|
|
const char *schema;
|
|
const char *query_text;
|
|
uint32_t query_len;
|
|
};
|
|
|
|
// Outcome of a query hook. ALLOW lets the query proceed to the
|
|
// backend. DENY returns an error to the client and the query never
|
|
// dispatches; the message is copied by core, the plugin need not keep
|
|
// it alive after the callback returns.
|
|
//
|
|
// NOTE: same std::string ABI coupling caveat as
|
|
// ProxySQL_PluginCommandResult applies.
|
|
enum class ProxySQL_PluginQueryHookAction : uint8_t {
|
|
allow = 0,
|
|
deny = 1
|
|
};
|
|
|
|
struct ProxySQL_PluginQueryHookResult {
|
|
ProxySQL_PluginQueryHookAction action;
|
|
std::string message;
|
|
};
|
|
|
|
using proxysql_plugin_query_hook_cb =
|
|
ProxySQL_PluginQueryHookResult (*)(const ProxySQL_PluginQueryHookPayload &);
|
|
|
|
// register_query_hook(proto, cb). Returns true on success, false if a
|
|
// hook for that protocol is already registered. Valid only during the
|
|
// init callback (same lifetime rule as register_table / register_command).
|
|
using proxysql_plugin_register_query_hook_cb =
|
|
bool (*)(ProxySQL_PluginProtocol, proxysql_plugin_query_hook_cb);
|
|
|
|
// Services provided to plugins during init.
|
|
// register_table/register_command: valid only during the init callback.
|
|
// get_*db, log_message, snapshots: valid for the plugin's entire lifetime.
|
|
struct ProxySQL_PluginServices {
|
|
proxysql_plugin_register_table_cb register_table;
|
|
proxysql_plugin_register_command_cb register_command;
|
|
proxysql_plugin_snapshot_cb get_mysql_users_snapshot;
|
|
proxysql_plugin_snapshot_cb get_mysql_servers_snapshot;
|
|
proxysql_plugin_snapshot_cb get_mysql_group_replication_hostgroups_snapshot;
|
|
proxysql_plugin_log_message_cb log_message;
|
|
proxysql_plugin_db_handle_cb get_admindb;
|
|
proxysql_plugin_db_handle_cb get_configdb;
|
|
proxysql_plugin_db_handle_cb get_statsdb;
|
|
// Step 2 ABI extension: pre-execution query hook. Older plugins
|
|
// that don't know about this field stop reading the struct at the
|
|
// previous member; new plugins check for non-null before calling.
|
|
proxysql_plugin_register_query_hook_cb register_query_hook;
|
|
};
|
|
|
|
using proxysql_plugin_init_cb =
|
|
bool (*)(ProxySQL_PluginServices *);
|
|
|
|
using proxysql_plugin_start_cb =
|
|
bool (*)();
|
|
|
|
using proxysql_plugin_stop_cb =
|
|
bool (*)();
|
|
|
|
// Returned pointer must have static storage duration (string literal or static
|
|
// buffer). The caller does not free it.
|
|
using proxysql_plugin_status_json_cb =
|
|
const char *(*)();
|
|
|
|
struct ProxySQL_PluginDescriptor {
|
|
const char *name;
|
|
uint32_t abi_version;
|
|
proxysql_plugin_init_cb init;
|
|
proxysql_plugin_start_cb start;
|
|
proxysql_plugin_stop_cb stop;
|
|
proxysql_plugin_status_json_cb status_json;
|
|
};
|
|
|
|
using proxysql_plugin_descriptor_v1_t = const ProxySQL_PluginDescriptor *(*)();
|
|
|
|
#endif /* PROXYSQL_PLUGIN_H */
|