The patch propagates initial_token option to the topology coordinator where it is added to join request parameter.
71 lines
1.7 KiB
C++
71 lines
1.7 KiB
C++
/*
|
|
* Copyright 2023-present ScyllaDB
|
|
*/
|
|
|
|
/*
|
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
|
*/
|
|
|
|
namespace service {
|
|
|
|
struct join_node_query_params {};
|
|
|
|
struct join_node_query_result {
|
|
enum class topology_mode : uint8_t {
|
|
legacy = 0,
|
|
raft = 1,
|
|
};
|
|
|
|
service::join_node_query_result::topology_mode topo_mode;
|
|
};
|
|
|
|
struct join_node_request_params {
|
|
raft::server_id host_id;
|
|
std::optional<raft::server_id> replaced_id;
|
|
std::vector<sstring> ignore_nodes;
|
|
sstring cluster_name;
|
|
sstring snitch_name;
|
|
sstring datacenter;
|
|
sstring rack;
|
|
sstring release_version;
|
|
uint32_t num_tokens;
|
|
sstring tokens_string;
|
|
uint32_t shard_count;
|
|
uint32_t ignore_msb;
|
|
std::vector<sstring> supported_features;
|
|
utils::UUID request_id;
|
|
};
|
|
|
|
struct join_node_request_result {
|
|
struct ok {};
|
|
struct rejected {
|
|
sstring reason;
|
|
};
|
|
|
|
std::variant<
|
|
service::join_node_request_result::ok,
|
|
service::join_node_request_result::rejected
|
|
> result;
|
|
};
|
|
|
|
struct join_node_response_params {
|
|
struct accepted {};
|
|
|
|
struct rejected {
|
|
sstring reason;
|
|
};
|
|
|
|
std::variant<
|
|
service::join_node_response_params::accepted,
|
|
service::join_node_response_params::rejected
|
|
> response;
|
|
};
|
|
|
|
struct join_node_response_result {};
|
|
|
|
verb join_node_query (raft::server_id dst_id, service::join_node_query_params) -> service::join_node_query_result;
|
|
verb join_node_request (raft::server_id dst_id, service::join_node_request_params) -> service::join_node_request_result;
|
|
verb join_node_response (raft::server_id dst_id, service::join_node_response_params) -> service::join_node_response_result;
|
|
|
|
}
|