2021-04-17 08:58:00 +08:00
|
|
|
/*
|
|
|
|
* ConfigFollowerInterface.h
|
|
|
|
*
|
|
|
|
* This source file is part of the FoundationDB open source project
|
|
|
|
*
|
|
|
|
* Copyright 2013-2018 Apple Inc. and the FoundationDB project authors
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "fdbclient/CommitTransaction.h"
|
|
|
|
#include "fdbclient/FDBTypes.h"
|
|
|
|
#include "fdbrpc/fdbrpc.h"
|
|
|
|
#include "fdbserver/CoordinationInterface.h"
|
|
|
|
|
|
|
|
struct ConfigFollowerGetVersionReply {
|
|
|
|
static constexpr FileIdentifier file_identifier = 1028349;
|
|
|
|
Version version;
|
|
|
|
|
|
|
|
explicit ConfigFollowerGetVersionReply(Version version = -1) : version(version) {}
|
|
|
|
|
|
|
|
template <class Ar>
|
|
|
|
void serialize(Ar& ar) {
|
|
|
|
serializer(ar, version);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
struct ConfigFollowerGetVersionRequest {
|
|
|
|
static constexpr FileIdentifier file_identifier = 9840156;
|
2021-04-17 11:20:41 +08:00
|
|
|
ReplyPromise<ConfigFollowerGetVersionReply> reply;
|
2021-04-17 08:58:00 +08:00
|
|
|
|
|
|
|
template <class Ar>
|
|
|
|
void serialize(Ar& ar) {
|
|
|
|
serializer(ar, reply);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
struct ConfigFollowerGetFullDatabaseReply {
|
|
|
|
static constexpr FileIdentifier file_identifier = 1734095;
|
|
|
|
std::map<Key, Value> database;
|
|
|
|
|
|
|
|
ConfigFollowerGetFullDatabaseReply() = default;
|
|
|
|
explicit ConfigFollowerGetFullDatabaseReply(std::map<Key, Value> const& database) : database(database) {
|
|
|
|
// TODO: Support move constructor as well
|
|
|
|
}
|
|
|
|
|
|
|
|
template <class Ar>
|
|
|
|
void serialize(Ar& ar) {
|
|
|
|
serializer(ar, database);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
struct ConfigFollowerGetFullDatabaseRequest {
|
|
|
|
static constexpr FileIdentifier file_identifier = 294811;
|
|
|
|
Version version;
|
|
|
|
Optional<Value> filter;
|
|
|
|
ReplyPromise<ConfigFollowerGetFullDatabaseReply> reply;
|
|
|
|
|
|
|
|
ConfigFollowerGetFullDatabaseRequest() : version(-1) {}
|
|
|
|
explicit ConfigFollowerGetFullDatabaseRequest(Version version, Optional<Value> filter)
|
|
|
|
: version(version), filter(filter) {}
|
|
|
|
|
|
|
|
template <class Ar>
|
|
|
|
void serialize(Ar& ar) {
|
|
|
|
serializer(ar, version, filter, reply);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2021-04-22 12:37:42 +08:00
|
|
|
struct VersionedMutationRef {
|
|
|
|
Version version;
|
|
|
|
MutationRef mutation;
|
|
|
|
|
|
|
|
VersionedMutationRef()=default;
|
|
|
|
explicit VersionedMutationRef(Arena &arena, Version version, MutationRef mutation) : version(version), mutation(arena, mutation) {}
|
2021-04-24 00:22:47 +08:00
|
|
|
explicit VersionedMutationRef(Arena& arena, VersionedMutationRef const& rhs)
|
|
|
|
: version(rhs.version), mutation(arena, rhs.mutation) {}
|
|
|
|
|
|
|
|
size_t expectedSize() const { return sizeof(Version) + mutation.expectedSize(); }
|
2021-04-22 12:37:42 +08:00
|
|
|
|
|
|
|
template<class Ar>
|
|
|
|
void serialize(Ar &ar) {
|
|
|
|
serializer(ar, version, mutation);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2021-04-17 08:58:00 +08:00
|
|
|
struct ConfigFollowerGetChangesReply {
|
|
|
|
static constexpr FileIdentifier file_identifier = 234859;
|
|
|
|
Version mostRecentVersion;
|
2021-04-22 12:37:42 +08:00
|
|
|
Standalone<VectorRef<VersionedMutationRef>> versionedMutations;
|
2021-04-17 08:58:00 +08:00
|
|
|
|
|
|
|
ConfigFollowerGetChangesReply() : mostRecentVersion(-1) {}
|
|
|
|
explicit ConfigFollowerGetChangesReply(Version mostRecentVersion,
|
2021-04-22 12:37:42 +08:00
|
|
|
Standalone<VectorRef<VersionedMutationRef>> const& versionedMutations)
|
|
|
|
: mostRecentVersion(mostRecentVersion), versionedMutations(versionedMutations) {}
|
2021-04-17 08:58:00 +08:00
|
|
|
|
|
|
|
template <class Ar>
|
|
|
|
void serialize(Ar& ar) {
|
2021-04-22 12:37:42 +08:00
|
|
|
serializer(ar, mostRecentVersion, versionedMutations);
|
2021-04-17 08:58:00 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
struct ConfigFollowerGetChangesRequest {
|
|
|
|
static constexpr FileIdentifier file_identifier = 178935;
|
|
|
|
Version lastSeenVersion;
|
|
|
|
Optional<Value> filter;
|
|
|
|
ReplyPromise<ConfigFollowerGetChangesReply> reply;
|
|
|
|
|
|
|
|
ConfigFollowerGetChangesRequest() : lastSeenVersion(-1) {}
|
|
|
|
explicit ConfigFollowerGetChangesRequest(Version lastSeenVersion, Optional<Value> filter)
|
|
|
|
: lastSeenVersion(lastSeenVersion), filter(filter) {}
|
|
|
|
|
|
|
|
template <class Ar>
|
|
|
|
void serialize(Ar& ar) {
|
|
|
|
serializer(ar, lastSeenVersion, reply);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2021-04-22 03:18:52 +08:00
|
|
|
struct ConfigFollowerCompactRequest {
|
|
|
|
static constexpr FileIdentifier file_identifier = 568910;
|
2021-04-24 00:22:47 +08:00
|
|
|
Version version;
|
2021-04-22 03:18:52 +08:00
|
|
|
ReplyPromise<Void> reply;
|
|
|
|
|
|
|
|
template <class Ar>
|
|
|
|
void serialize(Ar& ar) {
|
2021-04-24 00:22:47 +08:00
|
|
|
serializer(ar, version, reply);
|
2021-04-22 03:18:52 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2021-04-23 04:54:58 +08:00
|
|
|
struct ConfigFollowerInterface final : ReferenceCounted<ConfigFollowerInterface> {
|
2021-04-17 08:58:00 +08:00
|
|
|
static constexpr FileIdentifier file_identifier = 7721102;
|
|
|
|
RequestStream<ConfigFollowerGetVersionRequest> getVersion;
|
|
|
|
RequestStream<ConfigFollowerGetFullDatabaseRequest> getFullDatabase;
|
|
|
|
RequestStream<ConfigFollowerGetChangesRequest> getChanges;
|
2021-04-22 03:18:52 +08:00
|
|
|
RequestStream<ConfigFollowerCompactRequest> compact;
|
2021-04-17 08:58:00 +08:00
|
|
|
|
|
|
|
ConfigFollowerInterface() = default;
|
|
|
|
void setupWellKnownEndpoints() {
|
|
|
|
getVersion.makeWellKnownEndpoint(WLTOKEN_CONFIGFOLLOWER_GETVERSION, TaskPriority::Coordination);
|
|
|
|
getFullDatabase.makeWellKnownEndpoint(WLTOKEN_CONFIGFOLLOWER_GETFULLDB, TaskPriority::Coordination);
|
|
|
|
getChanges.makeWellKnownEndpoint(WLTOKEN_CONFIGFOLLOWER_GETCHANGES, TaskPriority::Coordination);
|
2021-04-22 03:18:52 +08:00
|
|
|
compact.makeWellKnownEndpoint(WLTOKEN_CONFIGFOLLOWER_COMPACT, TaskPriority::Coordination);
|
2021-04-17 08:58:00 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
ConfigFollowerInterface(NetworkAddress const& remote)
|
|
|
|
: getVersion(Endpoint({ remote }, WLTOKEN_CONFIGFOLLOWER_GETVERSION)),
|
|
|
|
getFullDatabase(Endpoint({ remote }, WLTOKEN_CONFIGFOLLOWER_GETFULLDB)),
|
2021-04-22 03:18:52 +08:00
|
|
|
getChanges(Endpoint({ remote }, WLTOKEN_CONFIGFOLLOWER_GETCHANGES)),
|
|
|
|
compact(Endpoint({ remote }, WLTOKEN_CONFIGFOLLOWER_COMPACT)) {}
|
2021-04-17 08:58:00 +08:00
|
|
|
|
|
|
|
template <class Ar>
|
|
|
|
void serialize(Ar& ar) {
|
|
|
|
serializer(ar, getVersion, getFullDatabase, getChanges);
|
|
|
|
}
|
|
|
|
};
|