Skip to content

Commit

Permalink
Add system table system.user_directories
Browse files Browse the repository at this point in the history
  • Loading branch information
Vitaly Baranov committed Aug 16, 2020
1 parent 0759dff commit 29a6558
Show file tree
Hide file tree
Showing 8 changed files with 96 additions and 0 deletions.
2 changes: 2 additions & 0 deletions src/Access/DiskAccessStorage.h
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,8 @@ class DiskAccessStorage : public IAccessStorage
~DiskAccessStorage() override;

const char * getStorageType() const override { return STORAGE_TYPE; }
String getStoragePath() const override { return directory_path; }
bool isStorageReadOnly() const override { return readonly; }

private:
std::optional<UUID> findImpl(EntityType type, const String & name) const override;
Expand Down
2 changes: 2 additions & 0 deletions src/Access/IAccessStorage.h
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,8 @@ class IAccessStorage
/// Returns the name of this storage.
const String & getStorageName() const { return storage_name; }
virtual const char * getStorageType() const = 0;
virtual String getStoragePath() const { return {}; }
virtual bool isStorageReadOnly() const { return false; }

using EntityType = IAccessEntity::Type;
using EntityTypeInfo = IAccessEntity::TypeInfo;
Expand Down
7 changes: 7 additions & 0 deletions src/Access/UsersConfigAccessStorage.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -482,6 +482,13 @@ UsersConfigAccessStorage::UsersConfigAccessStorage(const String & storage_name_,
UsersConfigAccessStorage::~UsersConfigAccessStorage() = default;


String UsersConfigAccessStorage::getStoragePath() const
{
std::lock_guard lock{load_mutex};
return path;
}


void UsersConfigAccessStorage::setConfig(const Poco::Util::AbstractConfiguration & config)
{
std::lock_guard lock{load_mutex};
Expand Down
2 changes: 2 additions & 0 deletions src/Access/UsersConfigAccessStorage.h
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,8 @@ class UsersConfigAccessStorage : public IAccessStorage
~UsersConfigAccessStorage() override;

const char * getStorageType() const override { return STORAGE_TYPE; }
String getStoragePath() const override;
bool isStorageReadOnly() const override { return true; }

void setConfig(const Poco::Util::AbstractConfiguration & config);

Expand Down
56 changes: 56 additions & 0 deletions src/Storages/System/StorageSystemUserDirectories.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
#include <Storages/System/StorageSystemUserDirectories.h>
#include <DataTypes/DataTypeString.h>
#include <DataTypes/DataTypesNumber.h>
#include <Columns/ColumnString.h>
#include <Columns/ColumnsNumber.h>
#include <Interpreters/Context.h>
#include <Access/AccessControlManager.h>
#include <ext/enumerate.h>


namespace DB
{
NamesAndTypesList StorageSystemUserDirectories::getNamesAndTypes()
{
NamesAndTypesList names_and_types{
{"name", std::make_shared<DataTypeString>()},
{"type", std::make_shared<DataTypeString>()},
{"path", std::make_shared<DataTypeString>()},
{"readonly", std::make_shared<DataTypeUInt8>()},
{"precedence", std::make_shared<DataTypeUInt64>()},
};
return names_and_types;
}


void StorageSystemUserDirectories::fillData(MutableColumns & res_columns, const Context & context, const SelectQueryInfo &) const
{
const auto & access_control = context.getAccessControlManager();
auto storages = access_control.getStorages();

size_t column_index = 0;
auto & column_name = assert_cast<ColumnString &>(*res_columns[column_index++]);
auto & column_type = assert_cast<ColumnString &>(*res_columns[column_index++]);
auto & column_path = assert_cast<ColumnString &>(*res_columns[column_index++]);
auto & column_readonly = assert_cast<ColumnUInt8 &>(*res_columns[column_index++]);
auto & column_precedence = assert_cast<ColumnUInt64 &>(*res_columns[column_index++]);

auto add_row = [&](const IAccessStorage & storage, size_t precedence)
{
const String & name = storage.getStorageName();
std::string_view type = storage.getStorageType();
const String & path = storage.getStoragePath();
bool readonly = storage.isStorageReadOnly();

column_name.insertData(name.data(), name.length());
column_type.insertData(type.data(), type.length());
column_path.insertData(path.data(), path.length());
column_readonly.insert(readonly);
column_precedence.insert(precedence);
};

for (auto [i, storage] : ext::enumerate(storages))
add_row(*storage, i + 1);
}

}
24 changes: 24 additions & 0 deletions src/Storages/System/StorageSystemUserDirectories.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
#pragma once

#include <ext/shared_ptr_helper.h>
#include <Storages/System/IStorageSystemOneBlock.h>


namespace DB
{
class Context;

/// Implements `users_directories` system table, which allows you to get information about user directories.
class StorageSystemUserDirectories final : public ext::shared_ptr_helper<StorageSystemUserDirectories>, public IStorageSystemOneBlock<StorageSystemUserDirectories>
{
public:
std::string getName() const override { return "SystemUserDirectories"; }
static NamesAndTypesList getNamesAndTypes();

protected:
friend struct ext::shared_ptr_helper<StorageSystemUserDirectories>;
using IStorageSystemOneBlock::IStorageSystemOneBlock;
void fillData(MutableColumns & res_columns, const Context & context, const SelectQueryInfo &) const override;
};

}
2 changes: 2 additions & 0 deletions src/Storages/System/attachSystemTables.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@
#include <Storages/System/StorageSystemQuotaLimits.h>
#include <Storages/System/StorageSystemQuotaUsage.h>
#include <Storages/System/StorageSystemQuotasUsage.h>
#include <Storages/System/StorageSystemUserDirectories.h>
#include <Storages/System/StorageSystemPrivileges.h>

#ifdef OS_LINUX
Expand Down Expand Up @@ -102,6 +103,7 @@ void attachSystemTablesLocal(IDatabase & system_database)
attach<StorageSystemQuotaLimits>(system_database, "quota_limits");
attach<StorageSystemQuotaUsage>(system_database, "quota_usage");
attach<StorageSystemQuotasUsage>(system_database, "quotas_usage");
attach<StorageSystemUserDirectories>(system_database, "user_directories");
attach<StorageSystemPrivileges>(system_database, "privileges");

#if !defined(ARCADIA_BUILD)
Expand Down
1 change: 1 addition & 0 deletions src/Storages/ya.make
Original file line number Diff line number Diff line change
Expand Up @@ -183,6 +183,7 @@ SRCS(
System/StorageSystemTableFunctions.cpp
System/StorageSystemTables.cpp
System/StorageSystemUsers.cpp
System/StorageSystemUserDirectories.cpp
System/StorageSystemZeros.cpp
System/StorageSystemZooKeeper.cpp
transformQueryForExternalDatabase.cpp
Expand Down

0 comments on commit 29a6558

Please sign in to comment.