diff --git a/src/replica/replica_config.cpp b/src/replica/replica_config.cpp index 10eaf4f0bc..8d99fa6321 100644 --- a/src/replica/replica_config.cpp +++ b/src/replica/replica_config.cpp @@ -525,7 +525,7 @@ void replica::update_ac_allowed_users(const std::map & allowed_users = iter->second; } - _access_controller->update(allowed_users); + _access_controller->update_allowed_users(allowed_users); } void replica::update_allow_ingest_behind(const std::map &envs) diff --git a/src/runtime/security/access_controller.cpp b/src/runtime/security/access_controller.cpp index 7e97dd7395..c0f1a42a15 100644 --- a/src/runtime/security/access_controller.cpp +++ b/src/runtime/security/access_controller.cpp @@ -26,11 +26,23 @@ namespace dsn { namespace security { DSN_DEFINE_bool(security, enable_acl, false, "whether enable access controller or not"); -DSN_TAG_VARIABLE(enable_acl, FT_MUTABLE); +DSN_DEFINE_bool(security, + enable_ranger_acl, + false, + "whether enable access controller integrate to Apache Ranger or not"); +DSN_DEFINE_string(security, + super_users, + "", + "super users for access controller, comma-separated list of user names"); -DSN_DEFINE_string(security, super_users, "", "super user for access controller"); - -access_controller::access_controller() { utils::split_args(FLAGS_super_users, _super_users, ','); } +access_controller::access_controller() +{ + // when FLAGS_enable_ranger_acl is true, FLAGS_enable_acl must be true. + // TODO(wanghao): check with DSN_DEFINE_group_validator(). + CHECK(!FLAGS_enable_ranger_acl || FLAGS_enable_acl, + "when FLAGS_enable_ranger_acl is true, FLAGS_enable_acl must be true too"); + utils::split_args(FLAGS_super_users, _super_users, ','); +} access_controller::~access_controller() {} @@ -42,6 +54,13 @@ bool access_controller::pre_check(const std::string &user_name) return false; } +bool access_controller::is_enable_ranger_acl() { return FLAGS_enable_ranger_acl; } + +bool access_controller::is_super_user(const std::string &user_name) const +{ + return _super_users.find(user_name) != _super_users.end(); +} + std::unique_ptr create_meta_access_controller() { return make_unique(); diff --git a/src/runtime/security/access_controller.h b/src/runtime/security/access_controller.h index eab1c509df..7ddbb233ec 100644 --- a/src/runtime/security/access_controller.h +++ b/src/runtime/security/access_controller.h @@ -21,6 +21,8 @@ #include #include +#include "runtime/ranger/ranger_resource_policy.h" + namespace dsn { class message_ex; namespace security { @@ -31,20 +33,33 @@ class access_controller access_controller(); virtual ~access_controller() = 0; - /** - * update the access controller - * acls - the new acls to update - **/ - virtual void update(const std::string &acls){}; + // Update the access controller. + // users - the new allowed users to update + virtual void update_allowed_users(const std::string &users) {} + + // Check whether the Ranger ACL is enabled or not. + bool is_enable_ranger_acl(); + + // Check if the message received is allowd to access the system. + // msg - the message received + virtual bool allowed(message_ex *msg, dsn::ranger::access_type req_type) { return false; } - /** - * check if the message received is allowd to do something. - * msg - the message received - **/ + // Check if the message received is allowd to access the table. + // msg - the message received + // app_name - tables involved in ACL + virtual bool allowed(message_ex *msg, const std::string &app_name) { return false; } + + // TODO(wanghao): this method will be deleted in the next patch. + // check if the message received is allowd to do something. + // msg - the message received virtual bool allowed(message_ex *msg) = 0; protected: + // TODO(wanghao): this method will be deleted in the next patch. bool pre_check(const std::string &user_name); + + // Check if 'user_name' is the super user. + bool is_super_user(const std::string &user_name) const; friend class meta_access_controller_test; std::unordered_set _super_users; @@ -52,6 +67,7 @@ class access_controller std::unique_ptr create_meta_access_controller(); -std::unique_ptr create_replica_access_controller(const std::string &name); +std::unique_ptr +create_replica_access_controller(const std::string &replica_name); } // namespace security } // namespace dsn diff --git a/src/runtime/security/replica_access_controller.cpp b/src/runtime/security/replica_access_controller.cpp index 6620c940ac..097ab05767 100644 --- a/src/runtime/security/replica_access_controller.cpp +++ b/src/runtime/security/replica_access_controller.cpp @@ -46,7 +46,7 @@ bool replica_access_controller::allowed(message_ex *msg) } } -void replica_access_controller::update(const std::string &users) +void replica_access_controller::update_allowed_users(const std::string &users) { { // check to see whether we should update it or not. diff --git a/src/runtime/security/replica_access_controller.h b/src/runtime/security/replica_access_controller.h index 47ffd46b11..c9771a0f65 100644 --- a/src/runtime/security/replica_access_controller.h +++ b/src/runtime/security/replica_access_controller.h @@ -27,7 +27,7 @@ class replica_access_controller : public access_controller public: explicit replica_access_controller(const std::string &name); bool allowed(message_ex *msg) override; - void update(const std::string &users) override; + void update_allowed_users(const std::string &users) override; private: utils::rw_lock_nr _lock; // [