1
0
Fork 0
arangodb/arangod/VocBase/VocbaseInfo.h

166 lines
5.0 KiB
C++

////////////////////////////////////////////////////////////////////////////////
/// DISCLAIMER
///
/// Copyright 2019 ArangoDB GmbH, Cologne, Germany
///
/// 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.
///
/// Copyright holder is ArangoDB GmbH, Cologne, Germany
///
/// @author Jan Christoph Uhde
////////////////////////////////////////////////////////////////////////////////
#ifndef ARANGOD_VOCBASE_VOCBASEINFO_H
#define ARANGOD_VOCBASE_VOCBASEINFO_H 1
#include <velocypack/Builder.h>
#include <velocypack/Slice.h>
#include <velocypack/velocypack-aliases.h>
#include "Basics/Result.h"
#include "Basics/debugging.h"
#include "VocBase/voc-types.h"
struct TRI_vocbase_t;
namespace arangodb {
namespace application_features {
class ApplicationServer;
}
// TODO do we need to add some sort of coordinator?
// builder.add("coordinator", VPackValue(ServerState::instance()->getId()));
struct DBUser {
DBUser() = default;
DBUser(DBUser const&) = default; // delete when info does not need to be copied anymore
DBUser(std::string&& n, std::string&& p, bool a, std::shared_ptr<VPackBuilder> b)
: name(std::move(n)), password(std::move(p)), extra(std::move(b)), active(a) {}
DBUser(std::string const& n, std::string const& p, bool a, std::shared_ptr<VPackBuilder> b)
: name(n), password(p), extra(std::move(b)), active(a) {}
DBUser& operator=(DBUser&& other) {
name = std::move(other.name);
password = std::move(other.password);
active = other.active;
extra = std::move(other.extra);
return *this;
}
DBUser(DBUser&& other) { operator=(std::move(other)); }
std::string name;
std::string password;
std::shared_ptr<VPackBuilder> extra; // TODO - must be unique_ptr eventually
bool active = false;
};
class CreateDatabaseInfo {
public:
explicit CreateDatabaseInfo(application_features::ApplicationServer&);
Result load(std::string const& name, uint64_t id);
Result load(uint64_t id, VPackSlice const& options,
VPackSlice const& users = VPackSlice::emptyArraySlice());
Result load(std::string const& name, VPackSlice const& options,
VPackSlice const& users = VPackSlice::emptyArraySlice());
Result load(std::string const& name, uint64_t id, VPackSlice const& options,
VPackSlice const& users);
Result load(VPackSlice const& options, VPackSlice const& users);
void toVelocyPack(VPackBuilder& builder, bool withUsers = false) const;
void UsersToVelocyPack(VPackBuilder& builder) const;
application_features::ApplicationServer& server() const;
uint64_t getId() const {
TRI_ASSERT(_valid);
TRI_ASSERT(_validId);
return _id;
}
bool validId() const { return _validId; }
// shold be created with vaild id
void setId(uint64_t id) {
_id = id;
_validId = true;
}
std::string const& getName() const {
TRI_ASSERT(_valid);
return _name;
}
std::uint32_t replicationFactor() const {
TRI_ASSERT(_valid);
return _replicationFactor;
}
std::uint32_t writeConcern() const {
TRI_ASSERT(_valid);
return _writeConcern;
}
std::string const& sharding() const {
TRI_ASSERT(_valid);
return _sharding;
}
ShardingPrototype shardingPrototype() const;
void shardingPrototype(ShardingPrototype type);
void allowSystemDB(bool s) { _isSystemDB = s; }
private:
Result extractUsers(VPackSlice const& users);
Result extractOptions(VPackSlice const& options, bool extactId = true,
bool extractName = true);
Result checkOptions();
private:
application_features::ApplicationServer& _server;
std::uint64_t _id = 0;
std::string _name = "";
std::string _sharding = "flexible";
std::vector<DBUser> _users;
std::uint32_t _replicationFactor = 1;
std::uint32_t _writeConcern = 1;
ShardingPrototype _shardingPrototype = ShardingPrototype::Undefined;
bool _validId = false;
bool _valid = false; // required because TRI_ASSERT needs variable in Release mode.
bool _isSystemDB = false;
};
struct VocbaseOptions {
std::string sharding = "";
std::uint32_t replicationFactor = 1;
std::uint32_t writeConcern = 1;
};
VocbaseOptions getVocbaseOptions(application_features::ApplicationServer&, velocypack::Slice const&);
void addClusterOptions(velocypack::Builder& builder, std::string const& sharding,
std::uint32_t replicationFactor,
std::uint32_t writeConcern);
void addClusterOptions(velocypack::Builder&, VocbaseOptions const&);
} // namespace arangodb
#endif