Skip to content

Commit

Permalink
Fixed crash when a library is set with a trailing /, fixes #552
Browse files Browse the repository at this point in the history
  • Loading branch information
epoupon committed Nov 14, 2024
1 parent ffc780d commit 7b47910
Show file tree
Hide file tree
Showing 5 changed files with 23 additions and 5 deletions.
2 changes: 2 additions & 0 deletions src/libs/core/test/Path.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -93,6 +93,8 @@ namespace lms::core::pathUtils::tests
{ "/root/", "/root/", true },
{ "/folder/file.txt", "/root", false },
{ "/folder/file.txt", "/root/", false },
{ "/file.txt", "/root", false },
{ "/file.txt", "/root/", false },
{ "", "/root", false },
};

Expand Down
13 changes: 11 additions & 2 deletions src/libs/database/impl/MediaLibrary.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -31,9 +31,9 @@
namespace lms::db
{
MediaLibrary::MediaLibrary(const std::filesystem::path& p, std::string_view name)
: _path{ p }
, _name{ std::string{ name, 0, maxNameLength } }
: _name{ std::string{ name, 0, maxNameLength } }
{
setPath(p);
}

MediaLibrary::pointer MediaLibrary::create(Session& session, const std::filesystem::path& p, std::string_view name)
Expand Down Expand Up @@ -77,4 +77,13 @@ namespace lms::db
func(mediaLibrary);
});
}

void MediaLibrary::setPath(const std::filesystem::path& p)
{
assert(p.is_absolute());
if (!p.has_filename() && p.has_parent_path())
_path = p.parent_path();
else
_path = p;
}
} // namespace lms::db
9 changes: 8 additions & 1 deletion src/libs/database/impl/Migration.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ namespace lms::db
{
namespace
{
static constexpr Version LMS_DATABASE_VERSION{ 73 };
static constexpr Version LMS_DATABASE_VERSION{ 74 };
}

VersionInfo::VersionInfo()
Expand Down Expand Up @@ -941,6 +941,12 @@ SELECT
utils::executeCommand(*session.getDboSession(), "UPDATE scan_settings SET scan_version = scan_version + 1");
}

void migrateFromV73(Session& session)
{
// Remove any trailing '/' in library paths
utils::executeCommand(*session.getDboSession(), "UPDATE media_library SET path = rtrim(path, '/') WHERE path LIKE '%/'");
}

bool doDbMigration(Session& session)
{
constexpr std::string_view outdatedMsg{ "Outdated database, please rebuild it (delete the .db file and restart)" };
Expand Down Expand Up @@ -990,6 +996,7 @@ SELECT
{ 70, migrateFromV70 },
{ 71, migrateFromV71 },
{ 72, migrateFromV72 },
{ 73, migrateFromV73 },
};

bool migrationPerformed{};
Expand Down
2 changes: 1 addition & 1 deletion src/libs/database/include/database/MediaLibrary.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ namespace lms::db

// setters
void setName(std::string_view name) { _name = name; }
void setPath(const std::filesystem::path& p) { _path = p; }
void setPath(const std::filesystem::path& p);

template<class Action>
void persist(Action& a)
Expand Down
2 changes: 1 addition & 1 deletion src/lms/ui/admin/MediaLibraryModal.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,7 @@ namespace lms::ui
if (p.is_relative())
return Wt::WValidator::Result(Wt::ValidationState::Invalid, Wt::WString::tr("Lms.Admin.MediaLibrary.path-must-be-absolute"));

// TODO check and translate rights issues
// TODO check and translate access rights issues
bool res{ std::filesystem::is_directory(p, ec) };
if (ec)
return Wt::WValidator::Result(Wt::ValidationState::Invalid, ec.message()); // TODO translate common errors
Expand Down

0 comments on commit 7b47910

Please # to comment.