/* * ModSecurity, http://www.modsecurity.org/ * Copyright (c) 2015 Trustwave Holdings, Inc. (http://www.trustwave.com/) * * 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 * * If any of the files related to licensing are missing or if you have any * other questions related to licensing please contact Trustwave Holdings, Inc. * directly using the email address security@modsecurity.org. * */ #ifdef __cplusplus #include #include #include #include #include #include #include #endif #include "modsecurity/collection/variable.h" #include "modsecurity/collection/collection.h" #ifndef SRC_COLLECTION_BACKEND_IN_MEMORY_PER_PROCESS_H_ #define SRC_COLLECTION_BACKEND_IN_MEMORY_PER_PROCESS_H_ #ifdef __cplusplus namespace modsecurity { namespace collection { namespace backend { /* * FIXME: * * This was an example grabbed from: * http://stackoverflow.com/questions/8627698/case-insensitive-stl-containers-e-g-stdunordered-set * * We have to have a better hash function, maybe based on the std::hash. * */ struct MyEqual { bool operator()(const std::string& Left, const std::string& Right) const { return Left.size() == Right.size() && std::equal(Left.begin(), Left.end(), Right.begin(), [](char a, char b) { return tolower(a) == tolower(b); }); } }; struct MyHash{ size_t operator()(const std::string& Keyval) const { // You might need a better hash function than this size_t h = 0; std::for_each(Keyval.begin(), Keyval.end(), [&](char c) { h += tolower(c); }); return h; } }; class InMemoryPerProcess : public std::unordered_multimap*/MyHash, MyEqual>, public Collection { public: InMemoryPerProcess(std::string name); ~InMemoryPerProcess(); void store(std::string key, std::string value) override; bool storeOrUpdateFirst(const std::string &key, const std::string &value) override; bool updateFirst(const std::string &key, const std::string &value) override; void del(const std::string& key) override; std::unique_ptr resolveFirst(const std::string& var) override; void resolveSingleMatch(const std::string& var, std::vector *l) override; void resolveMultiMatches(const std::string& var, std::vector *l) override; void resolveRegularExpression(const std::string& var, std::vector *l) override; private: pthread_mutex_t m_lock; }; } // namespace backend } // namespace collection } // namespace modsecurity #endif #endif // SRC_COLLECTION_BACKEND_IN_MEMORY_PER_PROCESS_H_