26#ifndef MYSQLROUTER_CLUSTER_METADATA_INCLUDED
27#define MYSQLROUTER_CLUSTER_METADATA_INCLUDED
130 for (
size_t i = 0; i <
N; ++i) {
144 for (
size_t i = 0; i <
N; ++i) {
179 const std::string &
value =
"")
208 "_disconnect_existing_sessions_when_hidden"};
287 const uint32_t router_id,
const std::string &hostname_override =
"") = 0;
303 const std::string &router_name,
const bool overwrite,
304 const std::string &hostname_override =
"") = 0;
307 const uint32_t router_id,
const std::string &cluster_id,
308 const std::string &target_cluster,
const std::string &rw_endpoint,
309 const std::string &ro_endpoint,
const std::string &rw_split_endpoint,
310 const std::string &rw_x_endpoint,
const std::string &ro_x_endpoint,
311 const std::string &username,
const std::string &local_cluster) = 0;
348 const std::string &new_accounts)
const = 0;
350 virtual std::vector<std::tuple<std::string, unsigned long>>
361 const std::string & ) {
414 uint32_t router_id,
const std::string &hostname_override =
"")
override;
417 const uint32_t router_id,
const std::string &cluster_id,
418 const std::string &target_cluster,
const std::string &rw_endpoint,
419 const std::string &ro_endpoint,
const std::string &rw_split_endpoint,
420 const std::string &rw_x_endpoint,
const std::string &ro_x_endpoint,
421 const std::string &username,
const std::string &local_cluster)
override;
423 uint32_t
register_router(
const std::string &router_name,
const bool overwrite,
424 const std::string &hostname_override =
"")
override;
427 const std::string &new_accounts)
const override;
465 uint64_t
get_view_id(
const std::string &cluster_type_specific_id)
override;
468 const uint32_t router_id,
const std::string &cluster_id,
469 const std::string &target_cluster,
const std::string &rw_endpoint,
470 const std::string &ro_endpoint,
const std::string &rw_split_endpoint,
471 const std::string &rw_x_endpoint,
const std::string &ro_x_endpoint,
472 const std::string &username,
const std::string &local_cluster)
override;
508 const std::string & )
override;
513 uint32_t router_id,
const std::string &hostname_override =
"")
override;
516 const uint32_t router_id,
const std::string &cluster_id,
517 const std::string &target_cluster,
const std::string &rw_endpoint,
518 const std::string &ro_endpoint,
const std::string &rw_split_endpoint,
519 const std::string &rw_x_endpoint,
const std::string &ro_x_endpoint,
520 const std::string &username,
const std::string &local_cluster)
override;
522 uint32_t
register_router(
const std::string &router_name,
const bool overwrite,
523 const std::string &hostname_override =
"")
override;
526 const std::string &new_accounts)
const override;
Base class to allow multiple SocketOperations implementations (at least one "real" and one mock for t...
Definition: socket_operations.h:45
static SocketOperations * instance()
Definition: socket_operations.cc:42
Definition: mysql_session.h:157
Definition: cluster_metadata.h:173
void invalidated_cluster_routing_policy(const InvalidatedClusterRoutingPolicy value)
Definition: cluster_metadata.h:194
InvalidatedClusterRoutingPolicy invalidated_cluster_routing_policy() const
Definition: cluster_metadata.h:188
void target_value(const std::string &value)
Definition: cluster_metadata.h:193
TargetCluster(const TargetType type=TargetType::ByPrimaryRole, const std::string &value="")
Definition: cluster_metadata.h:178
TargetType
Definition: cluster_metadata.h:175
InvalidatedClusterRoutingPolicy
Definition: cluster_metadata.h:176
void target_type(const TargetType value)
Definition: cluster_metadata.h:192
std::string target_value_
Definition: cluster_metadata.h:201
TargetType target_type_
Definition: cluster_metadata.h:200
InvalidatedClusterRoutingPolicy invalidated_cluster_routing_policy_
Definition: cluster_metadata.h:202
std::string to_string() const
Definition: cluster_metadata.h:184
const char * c_str() const
Definition: cluster_metadata.h:185
TargetType target_type() const
Definition: cluster_metadata.h:187
Definition: expected.h:286
std::atomic< Type > N
Definition: ut0counter.h:225
std::chrono::milliseconds milliseconds
Definition: authorize_manager.cc:68
ValueType value(const std::optional< ValueType > &v)
Definition: gtid.h:83
Definition: instrumented_condition_variable.h:32
void ROUTER_CLUSTER_EXPORT verify_routing_guidelines_version(MySQLSession *mysql, const std::uint32_t router_id)
Definition: cluster_metadata.cc:460
std::string ROUTER_CLUSTER_EXPORT get_incompatible_server_version_msg(MySQLSession *mysql)
Definition: cluster_metadata.cc:1422
constexpr MetadataSchemaVersion kClusterSetsMetadataVersion
Definition: cluster_metadata.h:97
constexpr MetadataSchemaVersion kNewMetadataVersion
Definition: cluster_metadata.h:94
bool ROUTER_CLUSTER_EXPORT is_part_of_cluster_set(MySQLSession *mysql)
Definition: cluster_metadata.cc:1175
ClusterType
Definition: cluster_metadata.h:154
InstanceType
Definition: cluster_metadata.h:213
constexpr MetadataSchemaVersion kUpgradeInProgressMetadataVersion
Definition: cluster_metadata.h:103
std::map< std::string, std::string > OptionsMap
Definition: cluster_metadata.h:252
constexpr MetadataSchemaVersion kRequiredRoutingMetadataSchemaVersion[]
Definition: cluster_metadata.h:90
constexpr const std::string_view kNodeTagDisconnectWhenHidden
Definition: cluster_metadata.h:207
constexpr MetadataSchemaVersion kRoutingGuidelinesMetadataVersion
Definition: cluster_metadata.h:100
constexpr const std::string_view kNodeTagHidden
Definition: cluster_metadata.h:206
MetadataSchemaVersion ROUTER_CLUSTER_EXPORT get_metadata_schema_version(MySQLSession *mysql)
Definition: cluster_metadata.cc:493
std::string ROUTER_CLUSTER_EXPORT get_metadata_schema_uncompatible_msg(const mysqlrouter::MetadataSchemaVersion &version)
Definition: cluster_metadata.cc:451
stdx::expected< void, std::string > ROUTER_CLUSTER_EXPORT setup_metadata_session(MySQLSession &session)
Definition: cluster_metadata.cc:1348
bool ROUTER_CLUSTER_EXPORT is_server_version_compatible(MySQLSession *mysql)
Definition: cluster_metadata.cc:1418
const bool kDefaultCloseConnectionAfterRefreshClusterSet
Definition: cluster_metadata.h:233
bool ROUTER_CLUSTER_EXPORT check_group_has_quorum(MySQLSession *mysql)
Definition: cluster_metadata.cc:560
constexpr MetadataSchemaVersion kRequiredBootstrapSchemaVersion[]
Definition: cluster_metadata.h:87
const bool kDefaultCloseConnectionAfterRefreshCluster
Definition: cluster_metadata.h:232
constexpr const std::chrono::milliseconds kDefaultMetadataTTLClusterGRNotificationsON
Definition: cluster_metadata.h:224
ClusterType ROUTER_CLUSTER_EXPORT get_cluster_type(const MetadataSchemaVersion &schema_version, MySQLSession *mysql, unsigned int router_id=0)
Definition: cluster_metadata.cc:1216
constexpr const std::chrono::milliseconds kDefaultMetadataTTLClusterSet
Definition: cluster_metadata.h:226
const bool kDefaultUseGRNotificationsClusterSet
Definition: cluster_metadata.h:230
bool ROUTER_CLUSTER_EXPORT check_group_replication_online(MySQLSession *mysql)
Definition: cluster_metadata.cc:544
bool ROUTER_CLUSTER_EXPORT metadata_schema_version_is_compatible(const mysqlrouter::MetadataSchemaVersion &required, const mysqlrouter::MetadataSchemaVersion &available)
Definition: cluster_metadata.cc:437
constexpr const std::chrono::milliseconds kDefaultMetadataTTLCluster
Definition: cluster_metadata.h:222
std::unique_ptr< ClusterMetadata > ROUTER_CLUSTER_EXPORT create_metadata(const MetadataSchemaVersion &schema_version, MySQLSession *mysql, const OptionsMap &options={}, mysql_harness::SocketOperationsBase *sockops=mysql_harness::SocketOperations::instance())
Definition: cluster_metadata.cc:1256
constexpr const bool kNodeTagDisconnectWhenHiddenDefault
Definition: cluster_metadata.h:211
constexpr const bool kNodeTagHiddenDefault
Definition: cluster_metadata.h:210
std::optional< InstanceType > ROUTER_CLUSTER_EXPORT str_to_instance_type(const std::string &)
Definition: cluster_metadata.cc:1376
std::string ROUTER_CLUSTER_EXPORT to_string(const MetadataSchemaVersion &version)
Definition: cluster_metadata.cc:488
const bool kDefaultUseGRNotificationsCluster
Definition: cluster_metadata.h:229
Definition: options.cc:57
Definition: gcs_xcom_synode.h:64
struct result result
Definition: result.h:34
required uint64 version
Definition: replication_group_member_actions.proto:41
required string type
Definition: replication_group_member_actions.proto:34
#define ROUTER_CLUSTER_EXPORT
Definition: router_cluster_export.h:15
Definition: cluster_metadata.h:235
bool is_primary
Definition: cluster_metadata.h:244
std::string get_cluster_type_specific_id() const
Definition: cluster_metadata.h:246
std::string cluster_type_specific_id
Definition: cluster_metadata.h:239
std::string cluster_id
Definition: cluster_metadata.h:237
std::vector< std::string > metadata_servers
Definition: cluster_metadata.h:236
std::string name
Definition: cluster_metadata.h:241