aboutsummaryrefslogtreecommitdiffstats
path: root/src/libserver
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@rspamd.com>2023-10-21 14:07:30 +0100
committerVsevolod Stakhov <vsevolod@rspamd.com>2023-10-21 14:08:23 +0100
commit48fffd3548320827d8d65dcc258afd24ddc5aefe (patch)
treeb5e3e5189bee1dac8f6e95d584812edc5c01d754 /src/libserver
parent78f91465d1170b19d12411c5b6be224565f25b84 (diff)
downloadrspamd-48fffd3548320827d8d65dcc258afd24ddc5aefe.tar.gz
rspamd-48fffd3548320827d8d65dcc258afd24ddc5aefe.zip
[Minor] Simplify by using <filesystem>
Diffstat (limited to 'src/libserver')
-rw-r--r--src/libserver/hyperscan_tools.cxx97
1 files changed, 33 insertions, 64 deletions
diff --git a/src/libserver/hyperscan_tools.cxx b/src/libserver/hyperscan_tools.cxx
index ec051837e..dc0586107 100644
--- a/src/libserver/hyperscan_tools.cxx
+++ b/src/libserver/hyperscan_tools.cxx
@@ -18,6 +18,7 @@
#ifdef WITH_HYPERSCAN
#include <string>
+#include <filesystem>
#include "contrib/ankerl/unordered_dense.h"
#include "contrib/ankerl/svector.h"
#include "fmt/core.h"
@@ -103,41 +104,6 @@ private:
cleanup_maybe();
}
- /* Have to duplicate raii_file methods to use raw filenames */
- static auto get_dir(std::string_view fname) -> std::string_view
- {
- auto sep_pos = fname.rfind(G_DIR_SEPARATOR);
-
- if (sep_pos == std::string::npos) {
- return std::string_view{fname};
- }
-
- while (sep_pos >= 1 && fname[sep_pos - 1] == G_DIR_SEPARATOR) {
- sep_pos--;
- }
-
- return std::string_view{fname.data(), sep_pos};
- }
-
- static auto get_extension(std::string_view fname) -> std::string_view
- {
- auto sep_pos = fname.rfind(G_DIR_SEPARATOR);
-
- if (sep_pos == std::string::npos) {
- sep_pos = 0;
- }
-
- auto filename = std::string_view{fname.data() + sep_pos};
- auto dot_pos = filename.find('.');
-
- if (dot_pos == std::string::npos) {
- return std::string_view{};
- }
- else {
- return std::string_view{filename.data() + dot_pos + 1, filename.size() - dot_pos - 1};
- }
- }
-
public:
hs_known_files_cache(const hs_known_files_cache &) = delete;
hs_known_files_cache(hs_known_files_cache &&) = delete;
@@ -176,69 +142,72 @@ public:
void add_cached_file(const char *fname)
{
- auto mut_fname = std::string{fname};
- std::size_t sz;
+ auto fpath = std::filesystem::path{fname};
+ std::error_code ec;
- rspamd_normalize_path_inplace(mut_fname.data(), mut_fname.size(), &sz);
- mut_fname.resize(sz);
+ fpath = std::filesystem::canonical(fpath, ec);
- if (mut_fname.empty()) {
+ if (!ec) {
+ msg_err_hyperscan("invalid path: \"%s\", error message: %s", fname, ec.message().c_str());
+ return;
+ }
+
+ if (fpath.empty()) {
msg_err_hyperscan("attempt to add an empty hyperscan file!");
return;
}
- if (access(mut_fname.c_str(), R_OK) == -1) {
- msg_err_hyperscan("attempt to add non existing hyperscan file: %s, %s", mut_fname.c_str(),
+ if (!std::filesystem::exists(fpath)) {
+ msg_err_hyperscan("attempt to add non existing hyperscan file: %s, %s", fpath.c_str(),
strerror(errno));
return;
}
- auto dir = hs_known_files_cache::get_dir(mut_fname);
- auto ext = hs_known_files_cache::get_extension(mut_fname);
+ auto dir = fpath.parent_path();
+ auto ext = fpath.extension();
if (std::find_if(cache_dirs.begin(), cache_dirs.end(),
[&](const auto &item) { return item == dir; }) == std::end(cache_dirs)) {
- cache_dirs.emplace_back(std::string{dir});
+ cache_dirs.emplace_back(dir.string());
}
if (std::find_if(cache_extensions.begin(), cache_extensions.end(),
[&](const auto &item) { return item == ext; }) == std::end(cache_extensions)) {
- cache_extensions.emplace_back(std::string{ext});
+ cache_extensions.emplace_back(ext.string());
}
- auto is_known = known_cached_files.insert(mut_fname);
+ auto is_known = known_cached_files.insert(fpath.string());
msg_debug_hyperscan("added %s hyperscan file: %s",
is_known.second ? "new" : "already known",
- mut_fname.c_str());
+ fpath.c_str());
}
void delete_cached_file(const char *fname)
{
- auto mut_fname = std::string{fname};
- std::size_t sz;
+ auto fpath = std::filesystem::path{fname};
+ std::error_code ec;
+
+ fpath = std::filesystem::canonical(fpath, ec);
- rspamd_normalize_path_inplace(mut_fname.data(), mut_fname.size(), &sz);
- mut_fname.resize(sz);
+ if (!ec) {
+ msg_err_hyperscan("invalid path to remove: \"%s\", error message: %s",
+ fname, ec.message().c_str());
+ return;
+ }
- if (mut_fname.empty()) {
+ if (fpath.empty()) {
msg_err_hyperscan("attempt to remove an empty hyperscan file!");
return;
}
- if (access(mut_fname.c_str(), R_OK) != -1) {
- if (unlink(mut_fname.c_str()) == -1) {
- msg_err_hyperscan("cannot remove hyperscan file %s: %s",
- mut_fname.c_str(), strerror(errno));
- }
- else {
- msg_debug_hyperscan("removed hyperscan file %s", mut_fname.c_str());
- }
+ if (unlink(fpath.c_str()) == -1) {
+ msg_err_hyperscan("cannot remove hyperscan file %s: %s",
+ fpath.c_str(), strerror(errno));
}
else {
- msg_err_hyperscan("attempt to remove non-existent hyperscan file %s: %s",
- mut_fname.c_str(), strerror(errno));
+ msg_debug_hyperscan("removed hyperscan file %s", fpath.c_str());
}
- known_cached_files.erase(mut_fname);
+ known_cached_files.erase(fpath.string());
}
auto cleanup_maybe() -> void