#pragma once #include #include #include #include #include #include #include #include namespace DB { /// Custom TLD List /// /// Unlike tldLookup (which uses gperf) this one uses plain StringHashSet. class TLDList { public: using Container = StringHashSet<>; explicit TLDList(size_t size); /// Return true if the tld_container does not contains such element. bool insert(StringRef host); /// Check is there such TLD bool has(StringRef host) const; size_t size() const { return tld_container.size(); } private: Container tld_container; std::unique_ptr pool; }; class TLDListsHolder { public: using Map = std::unordered_map; static TLDListsHolder & getInstance(); /// Parse "top_level_domains_lists" section, /// And add each found dictionary. void parseConfig(const std::string & top_level_domains_path, const Poco::Util::AbstractConfiguration & config); /// Parse file and add it as a Set to the list of TLDs /// - "//" -- comment, /// - empty lines will be ignored. /// /// Example: https://publicsuffix.org/list/public_suffix_list.dat /// /// Return size of the list. size_t parseAndAddTldList(const std::string & name, const std::string & path); /// Throws TLD_LIST_NOT_FOUND if list does not exist const TLDList & getTldList(const std::string & name); protected: TLDListsHolder(); std::mutex tld_lists_map_mutex; Map tld_lists_map TSA_GUARDED_BY(tld_lists_map_mutex); }; }