From 3e1e2420666f51741fe481e48aac6c3175f40653 Mon Sep 17 00:00:00 2001 From: Yibo He <1137195420@qq.com> Date: Fri, 8 Jul 2022 15:30:51 +0800 Subject: [PATCH] fix: add StringAdapter for Enforcer to pass policy as string (#204) --- casbin/enforcer.cpp | 2 +- casbin/persist/adapter.h | 3 +- casbin/persist/file_adapter/file_adapter.cpp | 5 ++ casbin/persist/file_adapter/file_adapter.h | 5 ++ casbin/persist/string_adapter.cpp | 90 +++++++++++++++++++ casbin/persist/string_adapter.h | 43 +++++++++ include/casbin/persist/adapter.h | 3 +- .../persist/file_adapter/file_adapter.h | 5 ++ include/casbin/persist/string_adapter.h | 43 +++++++++ 9 files changed, 196 insertions(+), 3 deletions(-) create mode 100644 casbin/persist/string_adapter.cpp create mode 100644 casbin/persist/string_adapter.h create mode 100644 include/casbin/persist/string_adapter.h diff --git a/casbin/enforcer.cpp b/casbin/enforcer.cpp index 10f831fc..6ad66ccd 100644 --- a/casbin/enforcer.cpp +++ b/casbin/enforcer.cpp @@ -228,7 +228,7 @@ Enforcer::Enforcer(const std::shared_ptr& m, std::shared_ptr ada this->Initialize(); - if (m_adapter && m_adapter->file_path != "") + if (m_adapter && m_adapter->IsValid()) this->LoadPolicy(); } diff --git a/casbin/persist/adapter.h b/casbin/persist/adapter.h index 26128db2..f93a3141 100644 --- a/casbin/persist/adapter.h +++ b/casbin/persist/adapter.h @@ -32,7 +32,6 @@ void LoadPolicyLine(std::string line, const std::shared_ptr& model); */ class Adapter { public: - std::string file_path; bool filtered; /** @@ -82,6 +81,8 @@ class Adapter { virtual void RemoveFilteredPolicy(std::string sec, std::string ptype, int field_index, std::vector field_values) = 0; virtual bool IsFiltered() = 0; + + virtual bool IsValid() = 0; }; }; // namespace casbin diff --git a/casbin/persist/file_adapter/file_adapter.cpp b/casbin/persist/file_adapter/file_adapter.cpp index 3b61c52a..60c998d2 100644 --- a/casbin/persist/file_adapter/file_adapter.cpp +++ b/casbin/persist/file_adapter/file_adapter.cpp @@ -113,6 +113,11 @@ bool FileAdapter ::IsFiltered() { return this->filtered; } +// IsValid returns true if the loaded policy is valid. +bool FileAdapter ::IsValid() { + return this->file_path != ""; +} + } // namespace casbin #endif // FILE_ADAPTER_CPP diff --git a/casbin/persist/file_adapter/file_adapter.h b/casbin/persist/file_adapter/file_adapter.h index a432a096..04e27006 100644 --- a/casbin/persist/file_adapter/file_adapter.h +++ b/casbin/persist/file_adapter/file_adapter.h @@ -9,6 +9,8 @@ namespace casbin { // It can load policy from file or save policy to file. class FileAdapter : virtual public Adapter { public: + std::string file_path; + // NewAdapter is the constructor for Adapter. FileAdapter(std::string file_path); @@ -35,6 +37,9 @@ class FileAdapter : virtual public Adapter { // IsFiltered returns true if the loaded policy has been filtered. bool IsFiltered(); + + // IsValid returns true if the loaded policy is valid. + bool IsValid(); }; }; // namespace casbin diff --git a/casbin/persist/string_adapter.cpp b/casbin/persist/string_adapter.cpp new file mode 100644 index 00000000..b8dfbae6 --- /dev/null +++ b/casbin/persist/string_adapter.cpp @@ -0,0 +1,90 @@ +#include "casbin/pch.h" + +#ifndef STRING_ADAPTER_CPP +#define STRING_ADAPTER_CPP + +#include + +#include "casbin/exception/casbin_adapter_exception.h" +#include "casbin/exception/io_exception.h" +#include "casbin/exception/unsupported_operation_exception.h" +#include "casbin/persist/string_adapter.h" +#include "casbin/util/util.h" + +namespace casbin { + +// NewAdapter is the constructor for Adapter. +StringAdapter ::StringAdapter(std::string line) { + this->line = line; + this->filtered = false; +} + +std::shared_ptr StringAdapter::NewStringAdapter(std::string line) { + return std::make_shared(line); +} + +// LoadPolicy loads all policy rules from the string buffer. +void StringAdapter ::LoadPolicy(const std::shared_ptr& model) { + if (this->line == "") + throw CasbinAdapterException("Invalid line, line cannot be empty"); + + std::vector strs = Split(this->line, "\n", -1); + for (int i = 0; i < strs.size(); i++) + LoadPolicyLine(strs[i], model); +} + +// SavePolicy saves all policy rules to the string buffer. +void StringAdapter ::SavePolicy(const std::shared_ptr& model) { + if (this->line == "") { + throw CasbinAdapterException("Invalid line, line cannot be empty"); + } + + std::string tmp; + + for (std::unordered_map>::iterator it = model->m["p"].assertion_map.begin(); it != model->m["p"].assertion_map.end(); it++) { + for (int i = 0; i < it->second->policy.size(); i++) { + tmp += it->first + ", "; + tmp += ArrayToString(it->second->policy[i]); + tmp += "\n"; + } + } + + for (std::unordered_map>::iterator it = model->m["g"].assertion_map.begin(); it != model->m["g"].assertion_map.end(); it++) { + for (int i = 0; i < it->second->policy.size(); i++) { + tmp += it->first + ", "; + tmp += ArrayToString(it->second->policy[i]); + tmp += "\n"; + } + } + + this->line = RTrim(tmp, "\n"); +} + +// AddPolicy adds a policy rule to the string buffer. +void StringAdapter ::AddPolicy(std::string sec, std::string p_type, std::vector rule) { + throw UnsupportedOperationException("not implemented"); +} + +// RemovePolicy removes a policy rule from the string buffer. +void StringAdapter ::RemovePolicy(std::string sec, std::string p_type, std::vector rule) { + this->line = ""; +} + +// RemoveFilteredPolicy removes policy rules that match the filter from the string buffer. +void StringAdapter ::RemoveFilteredPolicy(std::string sec, std::string p_type, int field_index, std::vector field_values) { + throw UnsupportedOperationException("not implemented"); +} + +// IsFiltered returns true if the loaded policy has been filtered. +bool StringAdapter ::IsFiltered() { + return this->filtered; +} + +// IsValid returns true if the loaded policy is valid. +bool StringAdapter ::IsValid() { + return this->line != ""; +} + +} // namespace casbin + +#endif // STRING_ADAPTER_CPP diff --git a/casbin/persist/string_adapter.h b/casbin/persist/string_adapter.h new file mode 100644 index 00000000..2b933502 --- /dev/null +++ b/casbin/persist/string_adapter.h @@ -0,0 +1,43 @@ +#ifndef CASBIN_CPP_PERSIST_STRING_ADAPTER_STRING_ADAPTER +#define CASBIN_CPP_PERSIST_STRING_ADAPTER_STRING_ADAPTER + +#include "./adapter.h" + +namespace casbin { + +// Adapter is the string adapter for Casbin. +// It can load policy from string buffer or save policy to string buffer. +class StringAdapter : virtual public Adapter { +public: + std::string line; + + // NewAdapter is the constructor for Adapter. + StringAdapter(std::string line); + + static std::shared_ptr NewStringAdapter(std::string line); + + // LoadPolicy loads all policy rules from the string buffer. + void LoadPolicy(const std::shared_ptr& model); + + // SavePolicy saves all policy rules to the string buffer. + void SavePolicy(const std::shared_ptr& model); + + // AddPolicy adds a policy rule to the string buffer. + void AddPolicy(std::string sec, std::string p_type, std::vector rule); + + // RemovePolicy removes a policy rule from the string buffer. + void RemovePolicy(std::string sec, std::string p_type, std::vector rule); + + // RemoveFilteredPolicy removes policy rules that match the filter from the string buffer. + void RemoveFilteredPolicy(std::string sec, std::string p_type, int field_index, std::vector field_values); + + // IsFiltered returns true if the loaded policy has been filtered. + bool IsFiltered(); + + // IsValid returns true if the loaded policy is valid. + bool IsValid(); +}; + +}; // namespace casbin + +#endif \ No newline at end of file diff --git a/include/casbin/persist/adapter.h b/include/casbin/persist/adapter.h index 066cb1c3..9e004e48 100644 --- a/include/casbin/persist/adapter.h +++ b/include/casbin/persist/adapter.h @@ -32,7 +32,6 @@ void LoadPolicyLine(std::string line, const std::shared_ptr& model); */ class Adapter { public: - std::string file_path; bool filtered; /** @@ -82,6 +81,8 @@ class Adapter { virtual void RemoveFilteredPolicy(std::string sec, std::string ptype, int field_index, std::vector field_values) = 0; virtual bool IsFiltered() = 0; + + virtual bool IsValid() = 0; }; }; // namespace casbin diff --git a/include/casbin/persist/file_adapter/file_adapter.h b/include/casbin/persist/file_adapter/file_adapter.h index a432a096..04e27006 100644 --- a/include/casbin/persist/file_adapter/file_adapter.h +++ b/include/casbin/persist/file_adapter/file_adapter.h @@ -9,6 +9,8 @@ namespace casbin { // It can load policy from file or save policy to file. class FileAdapter : virtual public Adapter { public: + std::string file_path; + // NewAdapter is the constructor for Adapter. FileAdapter(std::string file_path); @@ -35,6 +37,9 @@ class FileAdapter : virtual public Adapter { // IsFiltered returns true if the loaded policy has been filtered. bool IsFiltered(); + + // IsValid returns true if the loaded policy is valid. + bool IsValid(); }; }; // namespace casbin diff --git a/include/casbin/persist/string_adapter.h b/include/casbin/persist/string_adapter.h new file mode 100644 index 00000000..2b933502 --- /dev/null +++ b/include/casbin/persist/string_adapter.h @@ -0,0 +1,43 @@ +#ifndef CASBIN_CPP_PERSIST_STRING_ADAPTER_STRING_ADAPTER +#define CASBIN_CPP_PERSIST_STRING_ADAPTER_STRING_ADAPTER + +#include "./adapter.h" + +namespace casbin { + +// Adapter is the string adapter for Casbin. +// It can load policy from string buffer or save policy to string buffer. +class StringAdapter : virtual public Adapter { +public: + std::string line; + + // NewAdapter is the constructor for Adapter. + StringAdapter(std::string line); + + static std::shared_ptr NewStringAdapter(std::string line); + + // LoadPolicy loads all policy rules from the string buffer. + void LoadPolicy(const std::shared_ptr& model); + + // SavePolicy saves all policy rules to the string buffer. + void SavePolicy(const std::shared_ptr& model); + + // AddPolicy adds a policy rule to the string buffer. + void AddPolicy(std::string sec, std::string p_type, std::vector rule); + + // RemovePolicy removes a policy rule from the string buffer. + void RemovePolicy(std::string sec, std::string p_type, std::vector rule); + + // RemoveFilteredPolicy removes policy rules that match the filter from the string buffer. + void RemoveFilteredPolicy(std::string sec, std::string p_type, int field_index, std::vector field_values); + + // IsFiltered returns true if the loaded policy has been filtered. + bool IsFiltered(); + + // IsValid returns true if the loaded policy is valid. + bool IsValid(); +}; + +}; // namespace casbin + +#endif \ No newline at end of file