ClickHouse/dbms/Interpreters/InterpreterDropAccessEntityQuery.cpp

76 lines
2.3 KiB
C++
Raw Normal View History

2019-12-01 22:01:05 +00:00
#include <Interpreters/InterpreterDropAccessEntityQuery.h>
#include <Parsers/ASTDropAccessEntityQuery.h>
#include <Interpreters/Context.h>
#include <Access/AccessControlManager.h>
#include <Access/AccessFlags.h>
#include <Access/User.h>
#include <Access/Role.h>
2019-12-01 22:01:05 +00:00
#include <Access/Quota.h>
2019-11-29 17:22:56 +00:00
#include <Access/RowPolicy.h>
#include <Access/SettingsProfile.h>
2019-11-29 17:22:56 +00:00
#include <boost/range/algorithm/transform.hpp>
2019-12-01 22:01:05 +00:00
namespace DB
{
namespace
2019-12-01 22:01:05 +00:00
{
using Kind = ASTDropAccessEntityQuery::Kind;
std::type_index getType(Kind kind)
2019-12-01 22:01:05 +00:00
{
switch (kind)
{
case Kind::USER: return typeid(User);
case Kind::ROLE: return typeid(Role);
case Kind::QUOTA: return typeid(Quota);
case Kind::ROW_POLICY: return typeid(RowPolicy);
case Kind::SETTINGS_PROFILE: return typeid(SettingsProfile);
}
__builtin_unreachable();
}
AccessType getRequiredAccessType(Kind kind)
{
switch (kind)
{
case Kind::USER: return AccessType::DROP_USER;
case Kind::ROLE: return AccessType::DROP_ROLE;
case Kind::QUOTA: return AccessType::DROP_QUOTA;
case Kind::ROW_POLICY: return AccessType::DROP_POLICY;
case Kind::SETTINGS_PROFILE: return AccessType::DROP_SETTINGS_PROFILE;
}
__builtin_unreachable();
}
}
BlockIO InterpreterDropAccessEntityQuery::execute()
{
const auto & query = query_ptr->as<const ASTDropAccessEntityQuery &>();
auto & access_control = context.getAccessControlManager();
std::type_index type = getType(query.kind);
context.checkAccess(getRequiredAccessType(query.kind));
if (query.kind == Kind::ROW_POLICY)
{
Strings full_names;
boost::range::transform(
query.row_policies_names, std::back_inserter(full_names),
[this](const RowPolicy::FullNameParts & row_policy_name) { return row_policy_name.getFullName(context); });
if (query.if_exists)
access_control.tryRemove(access_control.find<RowPolicy>(full_names));
else
access_control.remove(access_control.getIDs<RowPolicy>(full_names));
return {};
2019-12-01 22:01:05 +00:00
}
if (query.if_exists)
access_control.tryRemove(access_control.find(type, query.names));
else
access_control.remove(access_control.getIDs(type, query.names));
return {};
2019-12-01 22:01:05 +00:00
}
2019-12-01 22:01:05 +00:00
}