mirror of
https://github.com/MariaDB/server.git
synced 2025-08-08 11:22:35 +03:00
P_S 5.7.28
This commit is contained in:
152
storage/perfschema/table_replication_connection_configuration.h
Normal file
152
storage/perfschema/table_replication_connection_configuration.h
Normal file
@@ -0,0 +1,152 @@
|
||||
/*
|
||||
Copyright (c) 2013, 2018, Oracle and/or its affiliates. All rights reserved.
|
||||
|
||||
This program is free software; you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License, version 2.0,
|
||||
as published by the Free Software Foundation.
|
||||
|
||||
This program is also distributed with certain software (including
|
||||
but not limited to OpenSSL) that is licensed under separate terms,
|
||||
as designated in a particular file or component or in included license
|
||||
documentation. The authors of MySQL hereby grant you an additional
|
||||
permission to link the program and your derivative works with the
|
||||
separately licensed software that they have included with MySQL.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License, version 2.0, for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program; if not, write to the Free Software
|
||||
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
|
||||
|
||||
|
||||
#ifndef TABLE_REPLICATION_CONFIGURATION_H
|
||||
#define TABLE_REPLICATION_CONFIGURATION_H
|
||||
|
||||
/**
|
||||
@file storage/perfschema/table_replication_connection_configuration.h
|
||||
Table replication_connection_configuration (declarations).
|
||||
*/
|
||||
|
||||
#include "pfs_column_types.h"
|
||||
#include "pfs_engine_table.h"
|
||||
#include "rpl_mi.h"
|
||||
#include "mysql_com.h"
|
||||
#include "my_thread.h"
|
||||
//#include "rpl_msr.h"
|
||||
//#include "rpl_info.h" /* CHANNEL_NAME_LENGTH*/
|
||||
|
||||
class Master_info;
|
||||
|
||||
/**
|
||||
@addtogroup Performance_schema_tables
|
||||
@{
|
||||
*/
|
||||
|
||||
#ifndef ENUM_RPL_YES_NO
|
||||
#define ENUM_RPL_YES_NO
|
||||
enum enum_rpl_yes_no {
|
||||
PS_RPL_YES= 1,
|
||||
PS_RPL_NO
|
||||
};
|
||||
#endif
|
||||
|
||||
/** enum values for SSL_Allowed*/
|
||||
enum enum_ssl_allowed {
|
||||
PS_SSL_ALLOWED_YES= 1,
|
||||
PS_SSL_ALLOWED_NO,
|
||||
PS_SSL_ALLOWED_IGNORED
|
||||
};
|
||||
|
||||
/**
|
||||
A row in the table. The fields with string values have an additional
|
||||
length field denoted by <field_name>_length.
|
||||
*/
|
||||
struct st_row_connect_config {
|
||||
char channel_name[CHANNEL_NAME_LENGTH];
|
||||
uint channel_name_length;
|
||||
char host[HOSTNAME_LENGTH];
|
||||
uint host_length;
|
||||
uint port;
|
||||
char user[USERNAME_LENGTH];
|
||||
uint user_length;
|
||||
char network_interface[HOSTNAME_LENGTH];
|
||||
uint network_interface_length;
|
||||
enum_rpl_yes_no auto_position;
|
||||
enum_ssl_allowed ssl_allowed;
|
||||
char ssl_ca_file[FN_REFLEN];
|
||||
uint ssl_ca_file_length;
|
||||
char ssl_ca_path[FN_REFLEN];
|
||||
uint ssl_ca_path_length;
|
||||
char ssl_certificate[FN_REFLEN];
|
||||
uint ssl_certificate_length;
|
||||
char ssl_cipher[FN_REFLEN];
|
||||
uint ssl_cipher_length;
|
||||
char ssl_key[FN_REFLEN];
|
||||
uint ssl_key_length;
|
||||
enum_rpl_yes_no ssl_verify_server_certificate;
|
||||
char ssl_crl_file[FN_REFLEN];
|
||||
uint ssl_crl_file_length;
|
||||
char ssl_crl_path[FN_REFLEN];
|
||||
uint ssl_crl_path_length;
|
||||
uint connection_retry_interval;
|
||||
ulong connection_retry_count;
|
||||
double heartbeat_interval;
|
||||
char tls_version[FN_REFLEN];
|
||||
uint tls_version_length;
|
||||
};
|
||||
|
||||
/** Table PERFORMANCE_SCHEMA.TABLE_REPLICATION_CONNECTION_CONFIGURATION. */
|
||||
class table_replication_connection_configuration: public PFS_engine_table
|
||||
{
|
||||
typedef PFS_simple_index pos_t;
|
||||
|
||||
private:
|
||||
void make_row(Master_info *);
|
||||
|
||||
/** Table share lock. */
|
||||
static THR_LOCK m_table_lock;
|
||||
/** Fields definition. */
|
||||
static TABLE_FIELD_DEF m_field_def;
|
||||
/** True if the current row exists. */
|
||||
bool m_row_exists;
|
||||
/** Current row */
|
||||
st_row_connect_config m_row;
|
||||
/** Current position. */
|
||||
pos_t m_pos;
|
||||
/** Next position. */
|
||||
pos_t m_next_pos;
|
||||
|
||||
protected:
|
||||
/**
|
||||
Read the current row values.
|
||||
@param table Table handle
|
||||
@param buf row buffer
|
||||
@param fields Table fields
|
||||
@param read_all true if all columns are read.
|
||||
*/
|
||||
|
||||
virtual int read_row_values(TABLE *table,
|
||||
unsigned char *buf,
|
||||
Field **fields,
|
||||
bool read_all);
|
||||
|
||||
table_replication_connection_configuration();
|
||||
|
||||
public:
|
||||
~table_replication_connection_configuration();
|
||||
|
||||
/** Table share. */
|
||||
static PFS_engine_table_share m_share;
|
||||
static PFS_engine_table* create();
|
||||
static ha_rows get_row_count();
|
||||
virtual int rnd_next();
|
||||
virtual int rnd_pos(const void *pos);
|
||||
virtual void reset_position(void);
|
||||
|
||||
};
|
||||
|
||||
/** @} */
|
||||
#endif
|
Reference in New Issue
Block a user