2010-08-09 10:32:50 +02:00
|
|
|
#include <mysql/plugin.h>
|
|
|
|
#include <mysql/services.h>
|
|
|
|
#include <mysql/service_my_snprintf.h>
|
|
|
|
extern struct my_snprintf_service_st {
|
|
|
|
size_t (*my_snprintf_type)(char*, size_t, const char*, ...);
|
|
|
|
size_t (*my_vsnprintf_type)(char *, size_t, const char*, va_list);
|
|
|
|
} *my_snprintf_service;
|
|
|
|
size_t my_snprintf(char* to, size_t n, const char* fmt, ...);
|
|
|
|
size_t my_vsnprintf(char *to, size_t n, const char* fmt, va_list ap);
|
|
|
|
#include <mysql/service_thd_alloc.h>
|
|
|
|
struct st_mysql_lex_string
|
|
|
|
{
|
|
|
|
char *str;
|
|
|
|
size_t length;
|
|
|
|
};
|
|
|
|
typedef struct st_mysql_lex_string MYSQL_LEX_STRING;
|
|
|
|
extern struct thd_alloc_service_st {
|
|
|
|
void *(*thd_alloc_func)(void*, unsigned int);
|
|
|
|
void *(*thd_calloc_func)(void*, unsigned int);
|
|
|
|
char *(*thd_strdup_func)(void*, const char *);
|
|
|
|
char *(*thd_strmake_func)(void*, const char *, unsigned int);
|
|
|
|
void *(*thd_memdup_func)(void*, const void*, unsigned int);
|
|
|
|
MYSQL_LEX_STRING *(*thd_make_lex_string_func)(void*, MYSQL_LEX_STRING *,
|
|
|
|
const char *, unsigned int, int);
|
|
|
|
} *thd_alloc_service;
|
|
|
|
void *thd_alloc(void* thd, unsigned int size);
|
|
|
|
void *thd_calloc(void* thd, unsigned int size);
|
|
|
|
char *thd_strdup(void* thd, const char *str);
|
|
|
|
char *thd_strmake(void* thd, const char *str, unsigned int size);
|
|
|
|
void *thd_memdup(void* thd, const void* str, unsigned int size);
|
|
|
|
MYSQL_LEX_STRING *thd_make_lex_string(void* thd, MYSQL_LEX_STRING *lex_str,
|
|
|
|
const char *str, unsigned int size,
|
|
|
|
int allocate_lex_string);
|
2010-10-05 14:26:49 +02:00
|
|
|
#include <mysql/service_thd_wait.h>
|
|
|
|
typedef enum _thd_wait_type_e {
|
2011-01-12 14:31:17 +01:00
|
|
|
THD_WAIT_SLEEP= 1,
|
2010-10-05 14:26:49 +02:00
|
|
|
THD_WAIT_DISKIO= 2,
|
2011-01-12 14:31:17 +01:00
|
|
|
THD_WAIT_ROW_LOCK= 3,
|
|
|
|
THD_WAIT_GLOBAL_LOCK= 4,
|
|
|
|
THD_WAIT_META_DATA_LOCK= 5,
|
|
|
|
THD_WAIT_TABLE_LOCK= 6,
|
|
|
|
THD_WAIT_USER_LOCK= 7,
|
|
|
|
THD_WAIT_BINLOG= 8,
|
|
|
|
THD_WAIT_GROUP_COMMIT= 9,
|
|
|
|
THD_WAIT_SYNC= 10,
|
|
|
|
THD_WAIT_LAST= 11
|
2010-10-05 14:26:49 +02:00
|
|
|
} thd_wait_type;
|
|
|
|
extern struct thd_wait_service_st {
|
2011-03-04 13:12:31 +01:00
|
|
|
void (*thd_wait_begin_func)(void*, int);
|
2010-10-05 14:26:49 +02:00
|
|
|
void (*thd_wait_end_func)(void*);
|
|
|
|
} *thd_wait_service;
|
2011-03-04 13:12:31 +01:00
|
|
|
void thd_wait_begin(void* thd, int wait_type);
|
2010-10-05 14:26:49 +02:00
|
|
|
void thd_wait_end(void* thd);
|
|
|
|
#include <mysql/service_thread_scheduler.h>
|
|
|
|
struct scheduler_functions;
|
|
|
|
extern struct my_thread_scheduler_service {
|
|
|
|
int (*set)(struct scheduler_functions *scheduler);
|
|
|
|
int (*reset)();
|
|
|
|
} *my_thread_scheduler_service;
|
|
|
|
int my_thread_scheduler_set(struct scheduler_functions *scheduler);
|
|
|
|
int my_thread_scheduler_reset();
|
2011-07-01 14:08:30 +02:00
|
|
|
#include <mysql/service_progress_report.h>
|
|
|
|
extern struct progress_report_service_st {
|
|
|
|
void (*thd_progress_init_func)(void* thd, unsigned int max_stage);
|
|
|
|
void (*thd_progress_report_func)(void* thd,
|
|
|
|
unsigned long long progress,
|
|
|
|
unsigned long long max_progress);
|
|
|
|
void (*thd_progress_next_stage_func)(void* thd);
|
|
|
|
void (*thd_progress_end_func)(void* thd);
|
|
|
|
const char *(*set_thd_proc_info_func)(void*, const char *info,
|
|
|
|
const char *func,
|
|
|
|
const char *file,
|
|
|
|
unsigned int line);
|
|
|
|
} *progress_report_service;
|
|
|
|
void thd_progress_init(void* thd, unsigned int max_stage);
|
|
|
|
void thd_progress_report(void* thd,
|
|
|
|
unsigned long long progress,
|
|
|
|
unsigned long long max_progress);
|
|
|
|
void thd_progress_next_stage(void* thd);
|
|
|
|
void thd_progress_end(void* thd);
|
|
|
|
const char *set_thd_proc_info(void*, const char * info, const char *func,
|
|
|
|
const char *file, unsigned int line);
|
2010-08-09 10:32:50 +02:00
|
|
|
struct st_mysql_xid {
|
|
|
|
long formatID;
|
|
|
|
long gtrid_length;
|
|
|
|
long bqual_length;
|
|
|
|
char data[128];
|
|
|
|
};
|
|
|
|
typedef struct st_mysql_xid MYSQL_XID;
|
|
|
|
enum enum_mysql_show_type
|
|
|
|
{
|
|
|
|
SHOW_UNDEF, SHOW_BOOL, SHOW_INT, SHOW_LONG,
|
|
|
|
SHOW_LONGLONG, SHOW_CHAR, SHOW_CHAR_PTR,
|
|
|
|
SHOW_ARRAY, SHOW_FUNC, SHOW_DOUBLE,
|
|
|
|
SHOW_always_last
|
|
|
|
};
|
|
|
|
struct st_mysql_show_var {
|
|
|
|
const char *name;
|
|
|
|
char *value;
|
|
|
|
enum enum_mysql_show_type type;
|
|
|
|
};
|
|
|
|
typedef int (*mysql_show_var_func)(void*, struct st_mysql_show_var*, char *);
|
|
|
|
struct st_mysql_sys_var;
|
|
|
|
struct st_mysql_value;
|
|
|
|
typedef int (*mysql_var_check_func)(void* thd,
|
|
|
|
struct st_mysql_sys_var *var,
|
|
|
|
void *save, struct st_mysql_value *value);
|
|
|
|
typedef void (*mysql_var_update_func)(void* thd,
|
|
|
|
struct st_mysql_sys_var *var,
|
|
|
|
void *var_ptr, const void *save);
|
|
|
|
struct st_mysql_plugin
|
|
|
|
{
|
|
|
|
int type;
|
|
|
|
void *info;
|
|
|
|
const char *name;
|
|
|
|
const char *author;
|
|
|
|
const char *descr;
|
|
|
|
int license;
|
|
|
|
int (*init)(void *);
|
|
|
|
int (*deinit)(void *);
|
|
|
|
unsigned int version;
|
|
|
|
struct st_mysql_show_var *status_vars;
|
|
|
|
struct st_mysql_sys_var **system_vars;
|
|
|
|
void * __reserved1;
|
2011-08-15 20:12:11 +02:00
|
|
|
unsigned long flags;
|
2010-08-09 10:32:50 +02:00
|
|
|
};
|
2011-07-02 22:12:12 +02:00
|
|
|
struct st_maria_plugin
|
|
|
|
{
|
|
|
|
int type;
|
|
|
|
void *info;
|
|
|
|
const char *name;
|
|
|
|
const char *author;
|
|
|
|
const char *descr;
|
|
|
|
int license;
|
|
|
|
int (*init)(void *);
|
|
|
|
int (*deinit)(void *);
|
|
|
|
unsigned int version;
|
|
|
|
struct st_mysql_show_var *status_vars;
|
|
|
|
struct st_mysql_sys_var **system_vars;
|
|
|
|
const char *version_info;
|
|
|
|
unsigned int maturity;
|
|
|
|
};
|
2010-08-09 10:32:50 +02:00
|
|
|
#include "plugin_ftparser.h"
|
|
|
|
#include "plugin.h"
|
|
|
|
enum enum_ftparser_mode
|
|
|
|
{
|
|
|
|
MYSQL_FTPARSER_SIMPLE_MODE= 0,
|
|
|
|
MYSQL_FTPARSER_WITH_STOPWORDS= 1,
|
|
|
|
MYSQL_FTPARSER_FULL_BOOLEAN_INFO= 2
|
|
|
|
};
|
|
|
|
enum enum_ft_token_type
|
|
|
|
{
|
|
|
|
FT_TOKEN_EOF= 0,
|
|
|
|
FT_TOKEN_WORD= 1,
|
|
|
|
FT_TOKEN_LEFT_PAREN= 2,
|
|
|
|
FT_TOKEN_RIGHT_PAREN= 3,
|
|
|
|
FT_TOKEN_STOPWORD= 4
|
|
|
|
};
|
|
|
|
typedef struct st_mysql_ftparser_boolean_info
|
|
|
|
{
|
|
|
|
enum enum_ft_token_type type;
|
|
|
|
int yesno;
|
|
|
|
int weight_adjust;
|
|
|
|
char wasign;
|
|
|
|
char trunc;
|
|
|
|
char prev;
|
|
|
|
char *quot;
|
|
|
|
} MYSQL_FTPARSER_BOOLEAN_INFO;
|
|
|
|
typedef struct st_mysql_ftparser_param
|
|
|
|
{
|
|
|
|
int (*mysql_parse)(struct st_mysql_ftparser_param *,
|
2011-07-02 22:12:12 +02:00
|
|
|
const char *doc, int doc_len);
|
2010-08-09 10:32:50 +02:00
|
|
|
int (*mysql_add_word)(struct st_mysql_ftparser_param *,
|
2011-07-02 22:12:12 +02:00
|
|
|
const char *word, int word_len,
|
2010-08-09 10:32:50 +02:00
|
|
|
MYSQL_FTPARSER_BOOLEAN_INFO *boolean_info);
|
|
|
|
void *ftparser_state;
|
|
|
|
void *mysql_ftparam;
|
2011-07-02 22:12:12 +02:00
|
|
|
const struct charset_info_st *cs;
|
|
|
|
const char *doc;
|
2010-08-09 10:32:50 +02:00
|
|
|
int length;
|
2011-07-02 22:12:12 +02:00
|
|
|
unsigned int flags;
|
2010-08-09 10:32:50 +02:00
|
|
|
enum enum_ftparser_mode mode;
|
|
|
|
} MYSQL_FTPARSER_PARAM;
|
|
|
|
struct st_mysql_ftparser
|
|
|
|
{
|
|
|
|
int interface_version;
|
|
|
|
int (*parse)(MYSQL_FTPARSER_PARAM *param);
|
|
|
|
int (*init)(MYSQL_FTPARSER_PARAM *param);
|
|
|
|
int (*deinit)(MYSQL_FTPARSER_PARAM *param);
|
|
|
|
};
|
|
|
|
struct st_mysql_daemon
|
|
|
|
{
|
|
|
|
int interface_version;
|
|
|
|
};
|
|
|
|
struct st_mysql_information_schema
|
|
|
|
{
|
|
|
|
int interface_version;
|
|
|
|
};
|
|
|
|
struct st_mysql_storage_engine
|
|
|
|
{
|
|
|
|
int interface_version;
|
|
|
|
};
|
|
|
|
struct handlerton;
|
|
|
|
struct Mysql_replication {
|
|
|
|
int interface_version;
|
|
|
|
};
|
|
|
|
struct st_mysql_value
|
|
|
|
{
|
|
|
|
int (*value_type)(struct st_mysql_value *);
|
|
|
|
const char *(*val_str)(struct st_mysql_value *, char *buffer, int *length);
|
|
|
|
int (*val_real)(struct st_mysql_value *, double *realbuf);
|
|
|
|
int (*val_int)(struct st_mysql_value *, long long *intbuf);
|
|
|
|
int (*is_unsigned)(struct st_mysql_value *);
|
|
|
|
};
|
|
|
|
int thd_in_lock_tables(const void* thd);
|
|
|
|
int thd_tablespace_op(const void* thd);
|
|
|
|
long long thd_test_options(const void* thd, long long test_options);
|
|
|
|
int thd_sql_command(const void* thd);
|
|
|
|
void **thd_ha_data(const void* thd, const struct handlerton *hton);
|
2010-10-05 14:26:49 +02:00
|
|
|
void thd_storage_lock_wait(void* thd, long long value);
|
2010-08-09 10:32:50 +02:00
|
|
|
int thd_tx_isolation(const void* thd);
|
|
|
|
char *thd_security_context(void* thd, char *buffer, unsigned int length,
|
|
|
|
unsigned int max_query_len);
|
|
|
|
void thd_inc_row_count(void* thd);
|
|
|
|
int mysql_tmpfile(const char *prefix);
|
|
|
|
int thd_killed(const void* thd);
|
|
|
|
unsigned long thd_get_thread_id(const void* thd);
|
|
|
|
void thd_get_xid(const void* thd, MYSQL_XID *xid);
|
|
|
|
void mysql_query_cache_invalidate4(void* thd,
|
|
|
|
const char *key, unsigned int key_length,
|
|
|
|
int using_trx);
|
|
|
|
void *thd_get_ha_data(const void* thd, const struct handlerton *hton);
|
|
|
|
void thd_set_ha_data(void* thd, const struct handlerton *hton,
|
|
|
|
const void *ha_data);
|
|
|
|
#include <mysql/plugin_auth_common.h>
|
|
|
|
typedef struct st_plugin_vio_info
|
|
|
|
{
|
|
|
|
enum { MYSQL_VIO_INVALID, MYSQL_VIO_TCP, MYSQL_VIO_SOCKET,
|
|
|
|
MYSQL_VIO_PIPE, MYSQL_VIO_MEMORY } protocol;
|
|
|
|
int socket;
|
|
|
|
} MYSQL_PLUGIN_VIO_INFO;
|
|
|
|
typedef struct st_plugin_vio
|
|
|
|
{
|
|
|
|
int (*read_packet)(struct st_plugin_vio *vio,
|
|
|
|
unsigned char **buf);
|
|
|
|
int (*write_packet)(struct st_plugin_vio *vio,
|
|
|
|
const unsigned char *packet,
|
|
|
|
int packet_len);
|
|
|
|
void (*info)(struct st_plugin_vio *vio, struct st_plugin_vio_info *info);
|
|
|
|
} MYSQL_PLUGIN_VIO;
|
|
|
|
typedef struct st_mysql_server_auth_info
|
|
|
|
{
|
2010-10-05 14:26:49 +02:00
|
|
|
char *user_name;
|
2010-08-09 10:32:50 +02:00
|
|
|
unsigned int user_name_length;
|
|
|
|
const char *auth_string;
|
|
|
|
unsigned long auth_string_length;
|
|
|
|
char authenticated_as[48 +1];
|
|
|
|
char external_user[512];
|
|
|
|
int password_used;
|
|
|
|
const char *host_or_ip;
|
|
|
|
unsigned int host_or_ip_length;
|
|
|
|
} MYSQL_SERVER_AUTH_INFO;
|
|
|
|
struct st_mysql_auth
|
|
|
|
{
|
|
|
|
int interface_version;
|
|
|
|
const char *client_auth_plugin;
|
|
|
|
int (*authenticate_user)(MYSQL_PLUGIN_VIO *vio, MYSQL_SERVER_AUTH_INFO *info);
|
|
|
|
};
|